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5 生 站 本 硬 古 和 是 到 


> 工作 应 用 速 查 : 本 书 实例 全 面 、 系 统 ， 涉 及 程序 开发 的 各 个 方面 ,适合 各 级 程序 开发 人 员 速 查 速 用 。 


> 项 目 开发 参考 : 程序 员 借助 本 书 提供 的 实例 源 代码 ， 可 以 快速 搭建 工程 项 目 ， 提 
> 学 习 实战 练习 : 入 门 者 的 实战 训练 大 人 全， 不 但 可 以 激发 学 习 兴趣 ， 更 可 提 


开发 效率 . 
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编程 实战 能 力 和 编程 思维 水 平 。 
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内 容 简 介 


《PHP 开发 实例 大 全 〈 基 础 卷 ) 》 短 选 、 汇 集 了 PHP 开发 从 基础 知识 到 高 级 应 用 各 个 层面 的 大 量 实例 及 源 代码 ， 
共有 600 个 左右 ， 每 个 实例 及 源 代码 按 实例 说 明 、 关 键 技术 、 设 计 过 程 、 详 尽 注释 、 秘 笈 心 法 的 顺序 进行 了 分 析 解读 。 
全 书 分 5 篇 15 章 ， 共 约 600 个 实例 ， 内 容 有 : 开发 环境 、PHP 基础 、Web 页 面 交互 、 文 件 操作 、 会 话 应 用 、 图 形 图 像 
处 理 、 面 向 对 象 、MySQL 数据 库 与 PHP、MySQL 高 级 应 用 技术 、PHP 操作 SQL Server 数据 库 、PHP 操作 Access 数据 
库 、PHP 操作 Oracle 数据 库 、ADODB 类 库 、Smarty 模板 、 综 合 应 用 。 配 书 光盘 附带 了 实例 的 源 程序 和 部 分 讲解 视频 。 

《PHP 开发 实例 大 全 基础 卷 )》 既 适合 PHP 程序 员 参 考 和 查阅 ， 也 适合 PHP 初学 者 ， 如 高 校 学 生 、 软 件 开发 培 
训 学 员 及 相关 求职 人 员 学 习 、 练 习 、 速 查 使 用 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 。 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举 报 电话 : 010-62782989 13701121933 


图 书 在 版 编目 《CIP) 数据 


PHP 开发 实例 大 全 .基础 卷 /软件 开发 技术 联盟 编著 .一 北京 : 清华 大 学 出 版 社 ，2016 
(软件 工程 师 开 发 大 系 ) 
ISBN 978-7-302-38474-8 


I OP… I @ 软 … II (DPHP 语言 -程序 设计 IV. TP312 
中 国 版 本 图 书馆 CIP 数据 核 字 (2014) 第 260802 号 


责任 编辑 : 赵 洛 育 
封面 设计 : 李 志 伟 
版 式 设计 : 刘 艳 庆 
责任 校对 : 赵 丽 杰 
责任 印 制 : 


出 版 发 行 : 清华 大 学 出 版 社 
网 址 : http://www.tup.com.cn，http://www.wqbook.com 
地 址 : 北京 清华 大 学 学 研 大 厦 A 座 邮 ” 编 : 100084 
社 总 机 : 010-62770175 邮  ” 购 : 010-62786544 
投稿 与 读者 服务 : 010-62776969，c-service@tup.tsinghua.edu.cn 
质量 反馈 : 010-62772015，zhiliang@tup.tsinghua.edu.cn 


印刷 者 : 
装 订 者 : 
经 ” 销 : 全 国 新 华 书店 
开 ”本 : 203mmX260mm 印 张 : 57.5 字 ” 数 : 1899 千 字 
《 附 光 盘 1 张 》 
版 ”次 : 2016 年 1 月 第 1 版 印 ”次 : 2016 年 1 月 第 1 次 印刷 
印 ” 数 : 1 一 3500 
定 价 : 128.00 元 


飞 
到 
游 
遇 


: 052243-01 


ac ” 主 
出 所 


特别 说 明 : 
《PHP 开发 实例 大 全 》 分 为 基础 卷 〈 即 本 书 ) 和 提高 卷 两 册 。 本 书 的 前 身 是 《PHP 开发 实战 1200 例 〈 第 
I 卷 ) 》。 


编写 目的 


1. 方便 程序 员 查阅 


程序 开发 是 一 项 艰辛 的 工作 ， 挑 灯 夜 战 、 加 班 加 点 是 常 有 的 事 。 在 开发 过 程 中 ， 一 个 技术 问题 可 能 会 占用 几 
天 甚至 更 长 时 间 。 如 果 有 一 本 开发 实例 大 全 可 供 翻阅 ， 从 中 找到 相似 的 实例 作 参考 ， 也 许 几 分 钟 就 可 以 解决 问题 。 
本 书 编写 的 主要 目的 就 是 方便 程序 员 查 阅 、 提 高 开发 效率 。 


2. 通过 分 析 大 量 源 代 码 ， 达 到 快速 学 习 之 目的 


本 书 提供 了 约 600 个 开发 实例 及 源 代码 ， 附 有 相应 的 注释 、 实 例 说明 、 关 键 技术 、 设 计 过 程 和 秘笈 心 法 ， 对 
实例 中 的 源 代码 进行 了 比较 透彻 的 解析 。 相 信 这 种 办 法 对 激发 学 习 兴 趣 、 提 高 学 习 效率 极 有 帮助 。 


3. 通过 阅读 大 量 源 代码 ， 达 到 提高 熟练 度 之 目的 


俗话 说 “ 熟 能 生 巧 ”， 读 者 只 有 通过 阅读 、 分 析 大 量 源 代码 ， 并 亲自 动手 去 做 ， 才 能 够 深刻 理解 、 运 用 自如 ， 
进而 提高 编程 熟练 度 ， 适 应 工作 之 需要 。 


4. 实例 源 程序 可 以 “ 拿 来 ”就 用 ， 提 高 了 效率 


本 书 的 很 多 实例 ， 可 以 根据 实际 应 用 需求 稍 加 改动 ， 拿 来 就 用 ， 不 必 再 去 从 头 编写 ， 从 而 节约 时 间 ， 提 高 工 
作 效 率 。 


本 书 内 容 


全 书 分 5 篇 15 章 ， 共 约 600 个 实例 ， 内 容 有 : 开发 环境 、PHP 基础 、Web 页 面 交互 、 文 件 操作 、 会 话 应 用 、 
图 形 图 像 处 理 、 面 向 对 象 、MySQL 数据 库 与 PHP、MySQL 高 级 应 用 技术 、PHP 操作 SQL Server 数据 库 、PHP 
操作 Access 数据 库 、PHP 操作 Oracle 数据 库 、ADODB 类 库 、Smarty 模板 、 综 合 应 用 。 书 中 所 选 实例 均 来 源 于 
一 线 开 发 人 员 的 实际 项 目 开发 ， 襄 括 了 开发 中 经 常 遇 到 和 需要 解决 的 热点 、 难 点 问题 ， 使 读者 可 以 快速 地 解决 开发 
中 的 难题 ， 提 高 编程 效率 。 本 书 知识 结构 如 下 图 所 示 。 

本 书 在 讲解 实例 时 采用 统一 的 编排 样式 ， 多 数 实例 由 “实例 说 明 ”“ 关 键 技术 ” “设计 过 程 ”“ 秘 笈 心 法 ” 
4 部 分 构成 。 其 中 ，“ 实 例 说 明 ” 部 分 采用 图 文 结合 的 方式 介绍 实例 的 功能 和 运行 效果 “关键 技术 ”部 分 介 
绍 了 实例 使 用 的 重点 、 难 点 技术 ; “设计 过 程 ”部 分 讲解 了 实例 的 详细 开发 过 程 ， “秘笈 心 法 ”部 分 给 出 了 与 
实例 相关 的 技巧 和 经 验 总 结 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


亮点 内 容 导航 
第 1 篇 基础 篇 (222 个 实例 )|| | 第 2 篇 ”常用 技术 篇 (124 个 实例 ) ||| 第 3 篇 ”数据库 篇 (191 个 实例 ) 
坟 I I I 于 I 到 I ] [ I I I ] 
加 语 | [3 Sileneale 豆 
w 应 图 时 语 
和 | | 反 || 星 || 可 | 革 | 对 | | 于 || 咒 | | 估 || 可 数 | | 作 | | 句 || 作 | | 作 || 作 
配 | | 号 | | || 数 | | 日 || 十 处 之 wm|| > 
置 || 写 | | 开 | | ~ | 期 || 和 下 加 | | 又 名 
引 | 估 | 朗 | 六 || 血 | | 名 ;| 
前 工 | | 组 | | 各 || 筷 砸 || 总 委 | | 数 || 数 
开 | | 化 | | 中 | | 的 | | 处 || 号 数 吾 | | 据 | | 据 
发 | | 安 应 | | 理 | | 页 指 数 | | 库 || 库 
环 | | 赣 用 | | 技 || 而 库 据 
境 | | 包 术 || 交 库 
互 
| 
第 4 篇 新 技术 篇 (44 个 实例 ) 第 5 篇 综合 应 用 篇 (44 个 实例 ) 
I I 
上 加 如 | [如 | 说 | [ 郊 ]| 站 | 网 [和 | [后 
站 || 册 | | 据 | | 内 | | 物 || 书 | | 台 
加 号 页 | | 公 || “| | 输 | | 搜 | | 车 || 订 | | 管 
模 面 | | 共 || 登 | | 出 | | 过 单 | | 理 
类 板 编 | | 文 || 录 处 | | 系 
库 码 | | 御 理 | | 统 
设 人 
计 录 


本 书 特点 


1. 实例 极为 丰富 


本 书 精 选 了 约 600 个 实例 ， 另 外 一 册 《PHP 开发 实例 大 全 〈 提 高 卷 ) 》 也 精 选 了 提高 部 分 约 600 个 实例 ， 
这 样 ， 两 册 图 书 总 计 约 1200 个 实例 ， 可 以 说 是 目前 市 场 上 实例 最 多 、 知 识 点 最 全 面 、 内 容 最 丰富 的 软件 开发 类 
图 书 ， 涵 盖 了 编程 中 各 个 方面 的 应 用 。 


2. 程序 解释 详尽 


本 书 提供 的 实例 及 源 代码 ， 附 有 相应 的 注释 、 实 例 说 明 、 关 键 技术 、 设 计 过 程 和 秘笈 心 法 。 分 析 解 释 详尽 
便于 快速 学 习 。 


3. 实践 实战 性 强 

本 书 的 实例 及 源 代 码 很 多 来 自 现实 开发 中 ， 光 盘 中 绝 大 多 数 实例 给 出 了 全 部 源 代 码 ， 读 者 可 以 直接 调用 、 研 
读 、 练 习 。 
关于 光盘 

1. 实例 学 习 注 意 事 项 


读者 在 按照 本 书 学 习 、 练 习 的 过 程 中 ， 可 以 从 光盘 中 复制 源 代码 ， 修 改 时 注意 去 掉 源码 文件 的 只 读 属性 。 
有 些 实例 需要 使 用 相应 的 数据 库 或 第 三 方 资源 ， 在 使 用 前 需要 进行 相应 配置 ， 具 体 步骤 请 参考 书 中 或 者 光盘 中 
的 配置 说 明 。 


前 


叫 


2. 实例 源 代码 及 视频 位 置 


本 书 光盘 提供 了 实例 的 源 代码 ， 位 置 在 光盘 中 的 “MR\ 章 号 \ 实 例 序 号 ”文件 夹 下， 例如 ，“MR\04\226” 表 示 
实例 226， 位 于 第 4 章 。 部 分 实例 提供 的 视频 讲解 ， 也 可 根据 以 上 方式 查找 。 由 于 有 些 实 例 源 代码 较 长 ， 限 于 篇 
幅 ， 图 书 中 只 给 出 了 关键 代码 ， 完 整 代码 放置 在 光盘 中 。 


3. 视频 使 用 说 明 
本 书 提供 了 部 分 实例 的 视频 讲解 ， 在 目录 中 标题 前 边 有 视频 图 标的 实例 ， 即 表示 在 光盘 中 有 视频 讲解 。 视 
频 采用 EXE 文件 格式 ， 无 须 使 用 播放 器 ， 双 击 就 可 以 直接 播放 。 
读者 对 象 
PHP 程序 员 ，PHP 初学 者 ， 如 高 校 大 学 生 、 求 职 人 员 、 培 训 机 构 学 员 等 。 
本 书 服务 


如 果 您 使 用 本 书 的 过 程 中 遇 到 问题 ， 可 以 通过 如 下 方式 与 我 们 联系 。 
服务 QQ: 4006751066 
服务 网 站 : http://www.mingribook.com 


本 书 作者 


本 书 由 软件 开发 技术 联盟 组 织 编写 ， 参 与 编写 的 程序 员 有 赛 硅 春 、 王 小 科 、 王 国 辉 、 王 占 龙 、 高 春 艳 、 张 
闭 、 杨 丽 、 辛 洪 郁 、 周 佳 星 、 申 小 琦 、 张 宝 华 、 葛 忠 月 、 王 雪 、 李 贺 、 吕 艳 妃 、 王 喜平 、 张 领 、 杨 贵 发 、 李 根 
福 、 刘 志 铭 、 宋 禹 蒙 、 刘 丽 艳 、 刘 莉莉 、 王 雨 竹 、 刘 红 艳 、 隋 光宇 、 郭 闭 、 崔 佳音 、 张 金辉 、 王 敬 洁 、 宋 晶 、 
刘 佳 、 陈 英 、 张 磊 、 张 世 辉 、 高 茹 、 陈 威 、 张 彦 国 、 高 飞 、 李 严 。 在 此 一 并 致谢 ! 
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1.1 AppServ 一 一 PHP 集成 化 安装 包 .. 
名 中 实例 001 通过 AppServ 配置 PHP 开发 环境 
鳃 和 实例 002 AppServ 应 用 技巧 
名 和 实例 003 第 1 个 PHP 程序 

1.2 XAMPP 一 一 PHP 集成 化 安装 包 .. 

实例 004 通过 XAMPP 配置 PHP 开发 环境 
实例 005 测试 XAMPP 是 否 安装 成 功 
实例 006 XAMPP 应 用 技巧 
实例 007 第 2 个 PHP 程序 
1.3 IIS+PHP+MySQL 一 一 独立 搭建 PHP 


实例 008 安装 PHP … 
实例 009 安装 MySQi 
实例 010 ”安装 IS.…… 
实例 011 第 3 个 PHP 程序 
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实例 019 第 5 个 PHP 程 序 … 
1.6 Dreamweaver 开发 工具 
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实例 021 Dreamweaver 中 创建 表格 


第 2 章 PHP 基础 


实例 022 在 表格 中 插入 宠物 照片 …… 
实例 023 ”Dreamweaver 中 创建 表单 .… 
实例 024 ”Dreamweaver 中 创建 和 附加 CSS 样式 
实例 025 Dreamweaver 控制 弹出 信息 .………… 
实例 026 ”Dreamweaver 控制 浏览 器 的 窗口 
实例 027 通过 Dreamweaver 创建 站 点 ….… 
实例 028 ”通过 Dreamweaver 开发 第 1 个 PHP 


1.7 Zend Studio 开发 工具 
实例 029 安装 Zend Studio..… 
实例 030 Zend Studio 创建 PHP 项 目 … 
实例 031 Zend Studio 编码 格式 的 转换 . 
实例 032 Zend Studio 中 快捷 键 的 运用 . 

鳃 和 实例 033 ”Zend studio 中 部 署 Apache 服务 器 


2.1 基本 语法 …. 
实例 034 在 页 面 中 打印 PHP 的 配置 信息 . 
实例 035 在 页 面 中 打印 服务 器 时 间 
实例 036 在 页 面 中 打印 当前 执行 的 PHP 文件 名 
实例 037 区 分 单 引号 和 双 引 号 …………………… 
实例 038 ”动态 输出 JavaScript 代码 
实例 039” 当 数字 遇 到 了 字符 串 .…. . 
实例 040 ”PHP 程序 员 的 基础 一 一 变量 的 应 用 ………72 
实例 041 打印 系统 环境 变量 信息 print r($_ENV) …73 

实例 042 ”使 用 可 变 变 量 输出 “ILike PHP!” 

实例 043 ”使 用 转 义 字符 输出 特殊 字符 

实例 044 ”使 用 常量 指定 PI 的 值 计 算 圆 的 面 


实例 045 自 定义 数字 的 加 密 /解密 算法 . 
实例 046 ”比较 两 个 时 间 戳 的 大 小 
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实例 048 
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2.4 条 件 语句 
实例 058 ”员工 生日 提醒 .…- 
实例 059 考试 成 绩 评定 标准 .… 
实例 060 ”控制 登录 用 户 权限 .… 
实例 061 网 页 框架 的 制作 . 
实例 062 
实例 063 ”健康 生活 提醒 . 
2.5 循环 语句 .....….…….. 
实例 064 ”员工 生日 列表 . 
实例 065 ”员工 详细 信息 浏览 .… 
实例 066 员工 信息 的 批量 删除 
实例 067 表格 的 动态 创建 
实例 068 ”SESSION 购物 车 中 数据 的 读 取 
实例 069 员工 信息 的 管理 . 
实例 070 ”网 页 版 九 九 乘法 表 . 
实例 071 读 取 数组 购物 车 中 的 数据 
器 实 例 072 图 像 验证 码 的 生成 … 
2.6 跳 转 语句 
实例 073 ”控制 页 面 中 表情 图 的 输出 
实例 074 ”控制 页 面 中 数据 的 输出 数量 ……… 
实例 075 动态 改变 页 面 中 单元 格 的 背景 颜色 . 
实例 076 ”屏蔽 偶数 次 的 数据 输出 … 
实例 077 ” 跳 过 数据 输出 中 指定 的 记录 
实例 078 执行 指定 次 数 的 循环 
2.7 自 定 义 函 数 
实例 079 自 定 义 函 数 截取 中 文字 符 串 
实例 080 ”公告 标题 的 截取 .…… 
实例 081 论坛 内 容 的 简短 输出 
实例 082” 自 定义 函数 过 滤 字 符 串 
2.8 ”字符 囊 
实例 083 过滤 论坛 帖子 中 的 空白 和 特殊 字符 . 


VI 


实例 084 
实例 085 
实例 086 
实例 087 
实例 088 
实例 089 
实例 090 
实例 091 
实例 092 
实例 093 
实例 094 
实例 095 
实例 096 
实例 097 
实例 098 
实例 099 
实例 100 
实例 101 
实例 102 
实例 103 
实例 104 
实例 105 
锯 # 实 例 106 
实例 107 


实例 108 
实例 109 
实例 110 


实例 111 
实例 112 


实例 113 
实例 114 


实例 115 


2.9 正则 表达 式 


实例 116 
实例 117 
实例 118 
实例 119 


对 论坛 帖子 的 内 容 进 行 转 义 
还 原 论坛 中 帖子 的 内 容 
截取 论坛 标题 ……… 
分 割 、 合 成 字符 串 
查询 关键 字 描 红 … 
统计 查询 关键 字 出 现 的 次 数 .… 
获取 上 传 文件 的 后 缀 ……… 
统一 上 传 文件 名 称 的 大 小 写 .… 
论坛 中 直接 输出 HTML 脚本 
统计 帖子 标题 的 长 度 … 
计算 论坛 帖子 的 字 节 数 
实现 帖子 内 容 的 定位 查找 .… 
去 除 帖子 标题 的 首尾 空格 … 
货币 数据 的 格式 化 输出 
日 期 、 时 间 的 格式 化 输出 … 
比 对 论坛 中 帖子 的 相似 度 
对 用 户 注册 的 密码 进行 加 密 和 解密 
保护 URL 地 址 中 传递 的 参数 
解析 URL 地 址 中 传递 的 编码 参数 . 
转 义 帖子 中 的 特殊 字符 …… 
获取 任意 字符 的 ASCI 码 . 
查找 指定 ASCII 码 对 应 的 字符 .. 
合理 定义 上 传 文件 的 名 称 
通过 异 或 方式 对 用 户 注册 密码 进行 


统一 英文 注册 用 户 首 字母 的 大 小 写 
字符 串 与 数字 之 间 的 转换 . 
通过 正则 表达 式 对 字符 串 进行 匹配 
查找 
通过 IP 地 址 查找 主机 所 在 地 
解决 用 substr0 函 数 对 中 文字 符 串 截取 时 
出 现 乱码 的 问题 ……………… 
字符 串 与 HTML 标记 相互 转换 . 
运用 PHP 5.0 新 型 字符 串 输出 XML 


判断 字符 串 中 是 否 存在 指定 子 串 


验证 电话 号 码 的 格式 是 否 正确 
验证 E-mail 地 址 格式 是 否 正确 .… 
验证 下 地 址 是 否 有 效 ………… 
统计 关键 字 的 查询 结果 ………………………… 150 


实例 120 
实例 121 


实例 122 
实例 123 


2.10 数组 . 


实例 124 
实例 125 
实例 126 
实例 127 
实例 128 
实例 129 
实例 130 
实例 131 
实例 132 
实例 133 
实例 134 
实例 135 
实例 136 
实例 137 
实例 138 
实例 139 


实例 140 


2.1l 
实例 141 
实例 142 
实例 143 
实例 144 
实例 145 
实例 146 
实例 147 

鳃 和 实例 148 


第 3 章 Web 页 面 交 互 … 
3.1 获取 表单 元 素 的 值 . 


鳃 和 实例 149 
实例 150 
实例 151 
实例 152 
实例 153 
实例 154 


3.2 文本 框 组 件 的 应 用 


实例 155 


计算 查询 操作 的 执行 时 间 
通过 正则 表达 式 蔡 换 函数 查询 
关键 字 描 红 .……… 
判断 上 传 文件 的 类 型 
判断 邮政 编码 格式 是 否 正确 


创建 并 输出 数组 
统计 数组 元 素 个 数 .… 
向 数组 中 添加 元 素 
将 数组 中 指定 索引 位 置 的 元 素 蔡 换 . 
获取 数组 中 最 后 一 个 元 素 
去 除数 组 中 的 重复 元 素 … 
字符 串 与 数组 的 转换 
对 数组 元 素 进行 随机 排序 
随机 抽取 数组 中 的 元 素 
二 维 数组 的 输出 …… 
获取 数组 当前 的 键 名 和 值 … 
检测 数组 中 是 否 存在 某 个 值 
获取 数组 中 的 当前 单元 
从 数组 中 随机 取出 元 素 


设置 系统 的 当前 时 间 
将 日 期 和 时 间 转 换 为 时 间 戳 … 
获取 系统 中 的 特定 日 期 和 时 间 
比较 时 间 的 大 小 . 
计算 考试 时 间 .… 
倒计时 … 

网 页 闹钟 
计算 各 序 沁 行 侍卫 sesssssssssansaene==176 


设计 论坛 登录 界面 .. 
可 以 上 传 图 片 的 表单 
通过 POST 方法 提交 表单 元 素 
通过 $_ POST 方法 获取 表单 元 素 
通过 GET 方法 提交 表单 元 素 .. 
通过 $_GET 方法 获取 表单 元 素 


以 文本 域 的 形式 显示 数据 信息 


实例 156 
实例 157 
实例 158 
实例 159 
实例 160 
实例 161 


3.3 下拉 列表 的 应 用 ... 


实例 162 
实例 163 
实例 164 
实例 165 
实例 166 
实例 167 
实例 168 
实例 169 


限制 多 行文 本 域 输入 的 字符 个 数 .……… 187 
设置 文本 框 的 只 读 属性 . 188 
自动 计算 金额 ……… 
为 文本 框 设置 默认 值 
设置 文本 框 的 样式 … 
文本 域 的 滚动 条 


省 、 市 级 联动 菜单 … 
省 、 市 、 县 级 联动 菜单 . 
应 用 下 拉 列 表 框 选择 所 要 联机 的 网 站 .…. 196 
可 输入 字符 的 下 拉 菜 单 
设置 下 拉 列 表 框 的 默认 值 .… 
设置 下 拉 列 表 框 的 样式 
应 用 下 拉 列 表 框 打开 窗口 .… 
Tab 键 在 文本 域 中 的 体现 … 


3.4 表单 元 素 的 动态 操作 


实例 170 
实例 171 
实例 172 
鳃 4 实例 173 
实例 174 
实例 175 
实例 176 
实例 177 
实例 178 
实例 179 
实例 180 
实例 181 
实例 182 
实例 183 


3.5 CSS+DIV 页 面 布局 


实例 184 
实例 185 
实例 186 
实例 187 
实例 188 
实例 189 
实例 190 
实例 191 
实例 192 
实例 193 


投票 系统 中 单 选 按钮 与 复 选 框 的 应 用 
选中 单 选 按钮 后 显示 其 他 表单 元 素 ………205 
不 提交 表单 获取 单 选 按钮 的 值 … 
实现 复 选 框 中 的 全 选 、 反 选 和 不 选 
隐藏 域 提交 用 户 的 ID 值 
图 像 域 蔡 代 提交 按钮 … 
跳 转 菜单 实现 页 面 跳 转 . 
上 传 图 片 预览 ……… 
去 掉 下 拉 列 表 框 的 边框 
修改 表单 属性 为 弹出 对 话 框 .. 
表单 输入 单元 的 文字 设置 .… 
表单 输入 单元 单 击 删 除 
表单 文本 输入 的 移动 选择 .… 
通过 下 拉 列 表 框 选择 头像.. 


应 用 CSS+DIV 实现 无 边框 窗口 
设置 图 片 的 样式 
设置 表单 样式 …… 
设置 超 链接 的 样式 
设置 body 的 样式 . 
模拟 的 进度 条 .… 
<div> 标 签 设 计 用 户 注册 页 面 
<div> 标 签 设计 论坛 帖子 浏览 页 面 ……… 234 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


实例 194 ” <div> 标签 设计 论坛 后 台 管 理 页 面 ……………… 236 
实例 195 ”<div> 标 签 设计 页 面 布局 
实例 196 页面 布局 (2 列 左 窄 右 宽 高 度 自 适 应 ).…… 
实例 197 页 面 布局 (2 列 固定 宽度 + 头 部 + 导航 + 


ed 242 
实例 198 页 面 布局 (3 列 左右 侧 固 定 中 间 自 适应 
居中 ) … .244 
实例 199 页 面 布局 〈2 列 右 侧 固定 左 侧 自 适应 
EO 247 
实例 200 页 面 布 局 (2 列 左 侧 固定 右 侧 自 适应 宽度 + 
| 
实例 201 页 面 布 局 (2 列 右 侧 固定 左 侧 自 适应 宽度 + 
底 平 齐 ) 


实例 202 弹出 指定 尺寸 的 无 边框 窗口 …. 
实例 203 全 屏 显示 无 边框 有 滚动 条 窗口 
实例 204 ”网 页 拾 色 器 .pe 
实例 205 日 期 选择 器 ………… 
实例 206 弹出 全 屏 显示 的 网 页 模式 对 话 框 . 


实例 207 关闭 正 主 窗口 时 不 弹出 询问 对 话 框 ……262 
实例 208 弹出 提示 对 话 框 并 重 定向 网 页 
实例 209 ”自动 关闭 的 广告 窗口 ……… 
实例 210 在 弹出 的 对 话 框 中 选择 个 性 头像 
实例 211 浮动 的 广告 窗口 .pp 
实例 212 在 页 面 右 下 角 弹 出 渐 显 的 广告 窗口 
3.7 状态 栏 设计 
实例 213 ”跑马 灯 文 字 .pe 
实例 214 ”状态 栏 中 的 收缩 显示 文字 .. 
实例 215 ”状态 栏 中 显示 数字 时 钟 . 
3.8 导航 菜单 设计 
名 4 实例 216 树 状 导航 菜单- 
实例 217 ”收缩 式 导航 菜单 
实例 218 ”展开 式 导 航 菜单 
实例 219 解释 型 菜单 . 
实例 220 半 透 明 背 景 的 下 拉 菜 单 . 
实例 221 二 级 导航 菜单 .. 
实例 222 导航 条 的 动画 效果 


第 2 篇 常用 技术 篇 


实例 223 ”以 二 进 制 形式 上 传 文件 到 数据 库 . 
鳃 和 实例 224 上 传 文件 到 服务 器 …… 
实例 225 限制 上 传 文件 的 大 小 .. 
实例 226 限制 上 传 文件 的 类 型 
实例 227 上 传 多 个 文件 到 服务 器 


实例 228 通过 链接 方式 下 载 … 
顽 4 实例 229 通过 header0 函 数 进行 下 载 . 


实例 230 读 取 整 个 文件 的 内 容 
吉 4 实例 231 文本 文件 的 分 页 读 取 
4.4 文件 操作 
实例 232 文件 操作 汇总 .… 
实例 233 目录 、 文 件 定位 器 . 
实例 234 ”改头换面 ……………… 


VII 


实例 235 文件 属性 分 析 … 
实例 236 文件 类 型 检测 .. 
实例 237 判断 文件 的 权限 ……………… 
实例 238 ”从 文本 文件 中 读 取 注册 服务 条 款 
实例 239 可 以 屏蔽 刷新 功能 的 文本 计数 器 
实例 240 ”判断 文件 是 否 被 修改 …………… 
实例 241 重新 定义 上 传 文件 的 名 称 .. 
实例 242 ” 读 取 远 程 文件 中 的 数据 . 
实例 243 ”删除 指定 目录 下 的 所 有 .ini 文件 … 
实例 244 ”将 文本 文件 中 的 数据 存储 到 数据 库 中 .….317 
4.5 文件 的 压缩 与 解压 
实例 245 PHP 中 压缩 RAR 文件 .. 
实例 246 PHP 中 将 上 传 文件 转换 成 RAR 文件 ….320 
实例 247 PHP 中 对 RAR 文件 进行 解压 
实例 248 PHP 中 压缩 ZP 文 件 ……… 
实例 249 PHP 中 解压 ZEP 文 件 
4.6 目录 操作 
实例 230 ”目录 操作 汇总 .324 


实例 251 重新 定义 目录 的 名 称 .ee 327 
实例 252 ”获取 磁盘 分 区 的 大 小 
实例 253 遍历 指定 目录 下 的 所 有 文件 
实例 254 遍历、 删除 指定 目录 下 的 所 有 文件 ……- 331 


第 5 章 会 话 应 用 
5.1 COOKIE 应用. 
实例 255 控制 登录 用 户 的 过 期 时 间 
名 和 实例 256 自动 登录 .… 
实例 257 单 击 登录 .… 
实例 258 ”统计 用 户 在 线 时 间 
实例 239 ”限制 用 户 访问 网 站 的 时 间 
实例 260 用 户 来 访 时 客户 端 创建 COOKIE . 
实例 261 删除 客户 端的 COOKIE 
实例 262 使 客户 端 浏览 器 支持 COOKIE 
5.2 SESSION 应 用 
实例 263 ”掌控 登录 用 户 的 权限 
名 和 实例 264 ”屏蔽 页 面 刷新 对 计数 器 的 影响 
实例 265 ”在 不 同 页 面 之 间 传 递 数据 
顽 4 实例 266 ”SESSION 购物 车 .…… 
实例 267 解决 SESSION 中 的 常见 问题 .. 
实例 268 ”控制 页 面 的 访问 权限 
实例 269 将 SESSION 数据 存储 到 数据 库 中 
实例 270 ”SESSION 更 换 聊天 室 界 面 
实例 271 清理 SESSION 缓存 提高 网 站 访问 的 
| 


第 6 章 图 形 图 像 处 理 .. 
6.1 
鳃 实例 272 图形 计数 器 … 
实例 273 ”GD2 图 形 计数 器 
实例 274 通过 图 像 显 示 投票 统计 结果 .… 
实例 275 通过 图 像 显 示 密 码 安全 强度 … 
袁 4 实例 276 数字 图 像 验证 码 
实例 277 ”中文 图 像 验证 码 . 
实例 278 缩 咯 图 艺术 库 .… 
实例 279 提取 图 像 的 EXIF 信息 
6.2 控制 、 显 示 图 片 特性 
实例 280 通过 鼠标 滑轮 控制 图 片 大 小 
实例 281 显示 随机 图 像 ……………………… 
实例 282 获取 页 面 中 图 像 的 实际 尺 十 
实例 283 ”图像 的 手动 播放 .…… 


录 


实例 284 图像 的 自动 播放 
实例 285 ”任意 调整 上 传 图 片 的 大 小 
实例 286 Apache 防盗 链 技术 …… 
实例 287 通过 SESSION 变量 防盗 链 
6.3 JpGraph 类 库 
实例 288 ” 柱 形 图 分 析 产品 月 销售 量 .. 
实例 289 柱 形 图 展示 年 度 收 支 情况 
实例 290 柱状 图 展示 编程 词典 6、7 月 份 销售 量 …391 
实例 291 柱状 图 展示 编程 词典 上 半年 销量 .………… 392 
实例 292 ” 柱 形 图 展示 2009 年 上 半年 总 销售 额 ……394 
名 4 实例 293 ” 柱 形 图 展示 2009 年 第 一 季度 编程 词典 
实例 294 ”折线 图 分 析 网 站 一 天 内 的 访问 走势 
实例 295” 柱 形 图 与 折线 图 分 析 图 书 销量 和 市 场 
尚 有 有 于 
实例 296 ”折线 图 分 析 2009 年 牛肉 市 场 价格 走势 …400 
实例 297 折线 图 分 析 2009 年 销售 额 
实例 298 ” 柱 形 图 分 析 编程 词典 销售 比例 
实例 299 饼 形 图 分 析 2009 年 图 书 销量 
实例 300 ” 饼 形 图 展示 各 语言 编程 词典 销售 比例 


实例 301 多 饼 形 图 区 块 分 析 2009 年 图 书 销 
实例 302 多 饼 形 图 分 析 2009 年 上 半年 编程 词典 
销量 408 
实例 303 ” 环 饼 形 图 分 析 2009 年 图 书 销 409 
6.4 GD2 函数 库 ... 


实例 304 绘制 基本 的 几何 图 形 
实例 305 GD2 函数 填充 几何 图 形 
实例 306 ”GD2 函数 输出 英文 字符 串 . 
实例 307 GD2 函数 在 照片 上 添加 文字 . 
句 4 实 例 308 GD2 函数 为 图 片 添加 文字 水 印 . 
实例 309 GD2 函数 为 图 片 添加 图 像 水 印 .. 
实例 310 GD2 函数 生成 图 形 验证 码 
实例 311 


实例 312 


实例 313 


第 7 章 、 面 向 对 煞 汪 sa 426 
7.1 类 的 定义 

鳃 中 实例 314 ”使 用 类 的 属性 保存 数据 库 连 接 参数 

鳃 中 实例 315 数据 库 连 接 类 中 定义 数据 库 连接 方法 ….428 


Kx 


PHP 开发 实例 大 全 (基础 卷 ) 


实例 316 数据 统计 类 中 定义 求 数值 平均 值 的 
使 用 重 载 实现 不 同类 型 数据 的 运算 - 
使 用 Sthis 关键 字 调 用 汽车 类 自身 的 


济 配 、… 


实例 317 
雪夫 例 318 


ON 
使 用 self 关键 字 调 用 学 生 类 自身 的 静态 


实例 319 


实例 320 
实例 321 


调用 汽车 类 中 的 刹车 方法 和 颜色 属性 …436 
学 生 类 中 使 用 构造 方法 为 学 生 信息 
圆 类 中 使 用 const 关键 字 定 
常量 2 
7.2 类 的 访问 修饰 符 .. 

实例 323 汽车 类 使 用 public 关键 字 定义 汽车 的 


实例 322 


和 烛 煌 太 法 ne 440 
实例 324 ”使 用 private 关键 字 定 义 汽车 的 颜色 

yO 441 
实例 325 ”使 用 protected 关键 字 定义 汽车 的 保修 

年 限 .. 


7.3 类 的 继承 . 
实例 326 苹果 子 类 继承 水 果 父 类 .… 
实例 327 使 用 parent 关键 字 调 用 父 类 的 方法 . 
实例 328 苹果 子 类 中 攻 盖 水 果 父 类 中 的 方法 . 

7.4 抽象 类 和 接口 
实例 329 美食 抽象 类 .…… 
实例 330 ”学生 类 多 重 接口 的 实现 


第 8 章 MySQL 数据 库 与 PHP.. 
8.1 MySQL 服务 器 的 启动 和 关闭 .. 
名 4 实例 347 启动 MySQL 服务 器 .. 

实例 348 连接 MySQL 服务 器 

实例 349 关闭 MySQL 服务 器 

8.2 MySQL 数据 库 

顽 4 实例 350 创建 PHP 图 书 数据 库 
实例 351 选择 PHP 图 书 数据 库 . 
实例 352 ”删除 PHP 图 书 数据 库 . 

8.3 MySQL 数据 表 
实例 353 在 PHP 图 书 数据 库 中 创建 图 书信 息 表 .…..487 


实例 331 通过 继承 实现 多 态 … 
实例 332 ”通过 接口 实现 多 态 .… 
7.6 常用 关键 字 
实例 333 ”使 用 final 关键 字 防 止 类 被 继承 . 
实例 334 ”使 用 static 关键 字 定义 类 的 静态 成 员 .….. 455 
实例 335 ”使 用 clone 关键 字 实 现 对 象 的 克隆 ………457 
实例 336 ”检测 当前 对 象 属于 哪个 类 .. 


使 用 _set0 方 法 为 类 中 未 声明 的 属性 


赋值 
使 用 _get0 方 法 获取 未 定义 属性 的 
名 称 
使 用 _call0 方 法 打印 类 中 未 定义 方法 
的 信息 . 
使 用 _toString0 方 法 将 类 的 实例 转换 为 
字符 串 . 
使 用 _isset( 方 法 提示 未 定义 属性 信息 …465 
使 用 _unset0 方 法 提示 未 定义 属性 
实例 343 ”使 用 _autoload0 方 法 自动 导入 类 文件 .….468 
Va 
实例 344 ”使 用 单 例 模式 制作 数据 库 管理 类 … 
实例 345 ”使 用 策略 模式 打印 客户 端 浏览 器 类 型 …471 
实例 346 ”使 用 工厂 模式 设置 用 户 访问 权限 …………473 


实例 339 


实例 340 


实例 341 
实例 342 


数据 库 篇 


实例 354 
实例 355 


查看 图 书信 息 表 … 

修改 图 书信 息 表 … 
实例 356 ” 重 命名 图 书信 息 表 
实例 357 ”删除 图 书信 息 表 … 

8.4 MySQL 数据 ................ 
实例 358 ”向 图 书信 息 表 中 添加 数据 .. 
实例 359 ”修改 图 书信 息 表 中 的 数据 .. 
实例 360 ”删除 图 书信 息 表 中 的 所 有 数据 … 
实例 361 ”删除 图 书信 息 表 中 的 指定 数据 .… 

8.5 PHP 操作 MySQL 数据库. 
实例 362 ”mysql_connect0 函 数 连接 MySQL 

服务 器 


实例 363 


实例 364 
实例 365 


实例 366 
实例 367 


实例 368 
实例 369 
实例 370 
实例 371 
实例 372 
实例 373 
实例 374 
实例 375 
鳃 和 实例 376 
实例 377 
实例 378 
实例 379 


8.6 SQL 查询 语句 


实例 380 
实例 381 
实例 382 
实例 383 
实例 384 
实例 385 
实例 386 
实例 387 
实例 388 
实例 389 
实例 390 
实例 391 
实例 392 
实例 393 
实例 394 
实例 395 
实例 396 
实例 397 
实例 398 


Imysql_select_db0 函 数 选择 MySQL 


mysql_query0 函 数 执行 SQL 语句 


mysql_fetch_array0 函 数 将 结果 返回 到 
抽风 ww 
mysql fetch_row0 函 数 从 结果 集中 获取 


mysql_result0 函 数 获 取 结果 数据 .… 
INSERT 语句 添加 图 书信 息 .… 
SELECT 语句 查询 图 书信 息 . 
分 页 显示 图 书信 息 .… 
UPDATE 语句 更 新 图 书信 息 
图 书信 息 的 批量 更 新 
DELETE 语句 删除 图 书信 息 
数据 信息 的 批量 删除 
避免 输出 中 文字 符 串 时 出 现 乱码 . 
动态 创建 MySQL 数据 库 
动态 创建 数据 表 
动态 创建 MySQL 数据 字段 . 


查询 数值 型 数据 . 


查询 日 期 型 数据 . 
查询 逻辑 型 数据 . 
查询 非 空 数据 . 
利用 变量 查询 数值 型 数据 
利用 变量 查询 字符 串 数据 
查询 前 n 条 记录 .……… 
查询 后 n 条 记录 
查询 从 指定 位 置 的 n 条 记录 
查询 统计 结果 中 的 前 n 条 记录 
查询 指定 时 间 段 的 数据 
按 月 查询 统计 数据 
查询 大 于 指定 条 件 的 记录 
查询 结果 不 显示 重复 记录 
not 与 谓词 进行 组 合 条 件 的 查询 过 
显示 数据 表 中 的 重复 记录 和 记录 条 数 ….538 
对 数据 进行 降序 查询 本 
对 数据 进行 多 条 件 排序 540 


实例 416 
实例 417 
实例 418 
实例 419 
实例 420 
实例 421 
实例 422 
实例 423 
实例 424 
实例 425 
实例 426 
实例 427 
实例 428 
实例 429 
实例 430 
实例 431 
实例 432 


实例 433 
实例 434 


对 统计 结果 进行 排序 ……………… 
单列 数据 分 组 统计 
多 列 数据 分 组 统计 
7 | 
使 用 聚集 函数 sumO 对 学 生成 绩 进行 


使 用 聚集 函数 avg0 求 学 生 的 平均 成 绩 .…547 
使 用 聚集 函数 min0 求 利润 最 少 的 商品 .… 548 
使 用 聚集 函数 max0 求 销售 利润 最 高 的 


使 用 聚集 函数 count0 求 利润 大 于 某 值 的 
聚集 函数 frst0 和 last0 的 使 用 


使 用 SELECT 语句 进行 多 表 查 询 
使 用 表 的 别名 进行 多 表 查 询 .… 
合并 多 个 结果 集 ………………… 
简单 的 嵌 套 查询 … 

复杂 的 嵌 套 查询 
赚 套 查询 在 查询 统计 中 的 应 用 
使 用 子 查 询 作 派生 的 表 . 
使 用 子 查 询 作 表 达 式 
使 用 子 查 询 关联 数据 
多 表 联 合 查询 …… 
对 联合 查询 后 的 结果 进行 排序 
条 件 联合 语句 .. 
简单 内 连接 查询 
复杂 内 连接 查询 
两 表 的 内 连接 关联 
使 用 外 连接 进行 多 表 联 合 查询 
left outer join 查询 . 
Tight outer join 查询 
利用 in 或 notin 关键 字 限 定 范围 
用 站 查询 表 中 的 记录 信息 .…. 
由 m 引入 的 关联 子 查询 
利用 transform 分 析 数 据 … 


利用 transform 动态 分 析 数 据 …………… 576 
使 用 格式 化 函数 转换 查询 条 件 的 数据 


在 查询 中 使 用 字符 串 函数 … 5 
在 查询 中 使 用 日 期 甫 数 …………………….. 580 


PHP 开发 实例 大 全 (基础 卷 ) 


实例 435 利用 having 语句 过 滤 分 组 数据 ………………… 582 
8.8 数据 的 导入 和 导出 

实例 436 MySQL 数据 自身 的 导入 和 导出 

实例 437 SQL Server 数据 导入 MySQL 


数据 库 … a 
实例 438 Access 数据 导入 到 M MySQL [数据 库 中 ed 586 
8.9 MySQL 数据 库 的 备份 和 恢复 588 


锅 和 实例 439 通过 命令 模式 备份 数据 库 .… 
实例 440 通过 phpMyAdmin 备份 数据 库 
实例 441 通过 手动 方式 备份 数据 库 … 
实例 442 通过 命令 模式 恢复 数据 库 .… 
实例 443 ”通过 phpMyAdmin 恢复 数据 库 
实例 444 ”通过 手动 方式 恢复 数据 库 … ee 

8.10 ” phpMyAdmin 图 形 化 管理 工具 593 
实例 445 通过 phpMyAdmin 修改 MySQL 用 户 
密码 … a ws 
实例 446 通过 A 设置 数据 库 、 数据 表 


顽 4 实例 447 phpMyAdmin 操作 数据 库 
实例 448” phpMyAdmin 操作 数据 表 
实例 449 phpMyAdmin 操作 数据 … 


第 9 章 MySQL 高 级 应 用 技术 600 
9.1 PHP 的 MySQLi 扩展 库 .Re 601 
实例 4530 ”使 用 MySQLi 扩展 库 连接 MySQL 
数据 库 … ee .601 
锅贴 实例 451 通过 MysQri 扩展 库 实现 数据 库 信 息 的 
nd 


实例 452 ”查看 服务 器 连接 错误 报告 ………… 
实例 453 通过 MySQLi 扩展 库 实现 多 表 查 询 . 
实例 454 通过 MySQLi 扩展 技术 实现 内 存 的 


实例 455 
实例 456 
实例 457 
实例 458 数据库 、 数 据 表 中 数据 的 动态 输出 . 
9.2 ”MySQL 视图 的 应 用 
实例 459 在 MySQL 数据 库 中 创建 视图 . 
实例 460 ”修改 MySQL 数据 库 中 的 视图 . 
实例 461 删除 MySQL 视图 a 
实例 462 ”使 用 MySQL 视图 查询 学 生成 绩 信息 …. 
9.3 MySQL 存储 过 程 
实例 463 创建 MySQL 存储 过 程 


XII 


铝 得 实例 464 使 用 存储 过 程 实现 用 户 登 录 
实例 465 “使 用 存储 过 程 实现 用 户 注册 .. 

9.4 MySQL 触发 器 
实例 466 创建 MySQL 触发 器 
实例 467 查看 MySQL 触发 器 


9.5 MySQL 事务 .… po 
实例 468 使 用 事务 处 理 技术 实现 关联 表 间 信 息 
和 刚刚 
实例 469 ”使 用 事务 处 理 技术 实现 银行 的 安全 
EN 628 
第 10 章 PHP 操作 SQL Server 数据 库 .…..630 
UB 演 基 区 掺 库 。aeweaoaEaaRaaeeee 631 


实例 470 ”通过 ADO 方式 连接 SQL Server 数据 库 …631 
实例 471 mssql_connectO 函 数 连接 SQL Server 


0 有 要 作 芝 据 库 。 ee 633 
实例 472 通过 ADO 方式 实现 指定 时 间 段 的 信息 


实例 473 ”检索 商品 信息 
实例 474 ”获取 指定 位 置 的 图 书信 
实例 475 取得 数据 中 指定 的 字段 信息 .… 
实例 476 ”利用 mssql_field_name0 函 数 获取 字段 

名 称 
实例 477 通过 结果 集 对 象 输出 数据 
实例 478 ”通过 结果 集 数 组 输出 数据 … 
实例 479 返回 结果 集中 的 单元 内 容 .… 
实例 480 ”利用 函数 返回 指定 字段 的 长 度 
实例 481 利用 函数 返回 指定 字段 的 类 型 
实例 482 ”取得 结果 集中 的 字段 数目 . 
实例 483 ”获取 数据 表 中 数据 记录 数 .… 
实例 484 ”mssql_free_result0 函 数 的 应 用 
实例 485 ”mssql_close0 函 数 的 应 用 …… 
实例 486 ”编写 数据 库 连接 类 .… 
实例 487 添加 图 书 类 的 实现 … 
实例 488 ”删除 图 书 类 的 实现 … 
实例 489 更 新 图 书 类 的 实现 … 
实例 490 ”通过 ADO 方式 实现 输入 页 码 跳 转 到 


实例 491 利用 mssql 函数 库 实 现 指定 页 跳 转 
10.3 SQL Server 数据 库 的 综合 应 用 .… 


负 和 实例 492 首页 设计 661 


句 4 实例 493 ”网 站 模块 导航 设计 
顽 4 实例 494 ”内 容 树 状 导 航 设计 .. 
鳃 中 实例 495 内容 展示 区 设计 
10.4 SQL Server 数据 库 的 安全 与 维护 ..….. 
实例 496 ”压缩 数据 库 …………. 
实例 497 ”收缩 日 志和 数据 . 
实例 498 ”备份 数据 库 …. 
实例 499 备份 事务 日 志 . 
实例 500 
实例 501 
实例 502 
实例 503 
实例 504 


定时 备份 数据 库 …… 
数据 库 中 数据 的 加 密 本 
SQL Server 数据 库 的 分 离 和 附加 …………… 677 
从 SQL Server 数据 库 导 出 数据 至 Excel 

实例 505 将 查询 到 的 数据 生成 一 个 Excel 文件 … 


第 11 章 PHP 操作 Access 数据 库 .. 
11.1 连接 数据 库 
实例 506 ”通过 COM 类 连接 Access 数据 库 . 
实例 507 连接 带 密码 的 Access 数据 库 .… 
11.2 操作 Access 数据 库 .. 
实例 508 ”通用 数据 信息 的 查询 
实例 509 查询 结果 的 分 页 显示 
实例 510 ”用户 身 份 验证 类 . 
实例 511 图 片 的 分 栏 显示 . 
实例 512 插入 图 书信 息 . 
实例 513 ”删除 图 书信 息 . 
11.3 ”Access 数据 库 的 安全 
实例 514 ”操作 带 密码 的 Access 数据 库 ge 
实例 515 ”防止 Access 数据 库 被 下 载 .…………………….695 


第 13 章 ADODB 类 库 
13.1 封装 ADODB 操作 类 
实例 338 ADODB 连接 数据 库 类 .…. 

实例 539 ADODB 操作 数据 库 类 .…. a 
实例 540 ADODB 分 页 类 .ee 


录 

11.4 Access 数据 库 的 综合 运用 .................. 
鳃 4 实例 516 ADODB 连接 Access 数据 库 . 
怠 4 实例 517 ADODB 操作 Access 数据 库 . 


实例 518 ”聊天 室 .…. 
实例 319 ”聊天 室 管理 . 


第 12 章 PHP 操作 Oracle 数据 库 .. 
12.1 连接 Oracle 数据 库 有 
实例 520 ”oci_connect0 函 数 连接 Oracle 数据 库 …… 
实例 521 ADODB 连接 Oracle 数据 库 ……… 
实例 522 ”删除 Oracle 数据 库 中 的 数据 . 
12.2 操作 Oracle 数据 库 
实例 523 ”员工 信息 的 添加 、 更 新 和 查询 
实例 524 下拉 列 表 框 值 的 动态 添加 .……… 
实例 525 ”统计 数据 库 中 数据 的 记录 数 …… 
实例 526 动态 获取 数据 表 中 的 字段 和 数据 
实例 527 ”获取 数据 表 中 字段 的 详细 信息 
实例 528 ”修改 Oracle 数据 库 用 户 的 密码 .… 
实例 329 ”应 用 事务 处 理 技术 确保 操作 的 同步 
实例 330 通过 PHP 变量 输出 数据 表 中 的 数据 
12.3 ”Oracle 数据 库 应 用 
勋 和 实例 531 Oracle 一 管理 员 注册 功 角 
实例 532 ”Oracle 一 一 管理 员 登 录 .…… 
实例 533 ”Oracle 一 一 管理 员 数 据 管 理 .… 
殴 4 本 例 534 ”smarty+ADODB 完成 Oracle 数据 的 分 页 
显示 
实例 535 Oracle 一 一 存储 过 程 更 新 员工 信息 
12.4 Oracle 数据 的 导入 和 导出 
实例 336 ”Oracle 数据 库 中 的 数据 导出 至 文本 文件 .…736 
贸 和 实例 537 文本 文件 中 的 数据 导入 至 Oracle.…………… 737 


729 


新 技术 篇 


132 DODB 的 写 同 nani 
实例 541 ADODB 分 页 技术 .………… 
实例 542 Adodb_pager 类 实现 分 页 功能 
实例 543 ADODB 操作 结果 集 的 方法 .… 
实例 544 ADODB 控制 结果 集 的 存 取 方法 
实例 545 一 次 连接 两 个 数据 库 ………………………. 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


实例 546 ADODB 连接 数据 库 类 pe 755 
实例 547 ADODB 生成 HTML 表格 ..757 
实例 548 ADODB 生成 下 拉 列表 框 ..758 
实例 549 ”事务 处 理 机 制 保证 数据 库 操作 的 


13.3 ADODB 中 的 错误 处 理 
实例 550 ”输出 系统 中 执行 的 SQL 语句 
实例 551 ErrorMsg 返回 错误 信息 .……- 
实例 552 返回 所 有 错误 信息 .……………… 
实例 553 ”将 错误 信息 存储 于 日 志文 件 中 

13.4 ADODB 操作 数据 库 

贸 和 实例 554 应 用 ADODB 访问 Access 数据 库 ……… 
句 4 实例 555 应 用 ADODB 访问 MySQL 数据 库 .…… 


766 
吉 4 实例 556 应 用 ADODB 访问 SQL Server 数据 库 .…768 
第 14 章 Smarty 模板 ...769 


14.1 环境 搭建 … 
名和 实例 557 smarty 开发 环境 措 建 . 
实例 558 ”Smarty 模板 的 配置 . 

名 和 实例 559 封装 Smarty 模板 的 配置 方法 
14.2 输出 数据 
实例 560 ”通过 让 语句 判断 当前 用 户 的 权限 . 
实例 561 Smarty 模板 中 生成 数字 验证 码 
实例 562 ”Smarty 模板 中 的 页 面 设计 


第 15 章 综合 应 用 
15.1 PHP 页 面 编码 
实例 582 ”设计 GB2312 编码 格式 的 网 页 . 
实例 583 ”设计 GBK 编码 格式 的 网 页 .. 
实例 584 ”设计 UTF-8 编码 格式 的 网 页 
实例 585 PHP 的 国际 化 .… 
15.2 网 站 公共 文件 设计 


名 和 实例 586 数据 库 连接 类 | 
实例 587 ”数据 库 管理 类 . ..827 
名 4 实例 588 ”数据库 分 页 类 ……… .829 
名 4 实例 589 smarty 模板 引擎 配置 类 .. .831 
实例 590 ”字符 串 处 理 类 .…. 
实例 591 网 站 的 头 文件 设计 .. 


实例 563 
实例 564 
实例 565 


实例 566 


14.3 ”综合 应 用 


实例 567 
鳃 和 实例 568 
实例 569 
实例 570 
詹 4 实 例 571 


实例 572 


实例 573 
实例 574 
实例 575 
实例 576 
实例 577 
实例 578 
实例 579 


实例 580 
实例 581 


Smarty 模板 中 直接 定义 CSS 样式 . 
Smarty 模板 中 嵌入 JavaScript 脚本 
html options 函数 向 下 拉 列表 框 中 添加 


Smarty 模板 制作 日 期 、 时 间 选 择 器 


Smarty 模板 制作 用 户 注册 页 面 .… 
Smarty 模板 制作 后 台 管理 系统 主页 
通过 section 循环 输出 数据 ……… 
Smarty 模板 中 数据 的 分 页 显示 
Smarty+ADODB 完成 数据 的 分 页 


Smarty 模板 中 的 编码 ……… 
Smarty 模板 中 应 用 正则 表达 式 .… 
Smarty 模板 中 的 关键 字 描 红 技 术 
Smarty 模板 中 控制 输出 字符 串 的 行 宽 
Tegister_object0 方 法 注册 模板 对 象 ………… 
register_function( 方 法 注册 模板 函数 …… 
Smarty 模板 中 truncate 方法 截取 

字符 串 . 
开启 网 站 注册 页 面 的 缓存 . 
通过 配置 文件 定义 变量 


综合 应 用 篇 


实例 592 
实例 593 
15.3 
镶 和 实例 594 
实例 595 
实例 596 
实例 597 
实例 598 


15.4 数据 的 输出 
鳃 和 实例 599 


实例 600 
实例 601 
实例 602 
实例 603 


注册 、 登 录 


网 站 的 尾 文件 设计 .cc 
首页 广告 设计 … 


用 户 登录 . 
用 户 中 心 . 
我 的 订单 . 
找 回 密码 . 


图 书 分 类 . 
特别 图 书 . 
图 书 试 读 . 
图 书 详细 信息 展示 


实例 604 ”新 闻 公 告 ……… 
15.5 站 内 搜索 … 
实例 605 一 般 搜索 
实例 606 高 级 搜索 


实例 607 购物 车 类 .……… 
实例 608 ”购物 车 功能 实现 . 
15.7 ”图书 订单 处 理 .... 
实例 609 填写 收 货 人 信息 . 
实例 610 确认 订购 信息 . 
实例 611 支付 宝 在 线 支付 . 
实例 612 工行 在 线 支付 .…… 
15.8 后 台 管 理 系统 登录 
实例 613 管理 员 登 录 
实例 614 ”后台 管理 系统 主页 设计 
15.9 系统 管理 
实例 615 系统 信息 设置 


录 


实例 616 更改 管 理 员 密 码 …………………… 
15.10 ”图书 类 别管 理 ... 
实例 617 图书 大 类 管理 
实例 618 ”图 书 小 类 管理 
实例 619 出 版 社 分 类 管理 
15.11 图 书 管理 
实例 620 ”图 书信 息 管理 . 
实例 621 图书 试 读 管理 .. 
15.12 用户 管 理 
实例 622 用户 信息 管理 . 
实例 623 用户 反馈 管理 ……. 
15.13 ”订单 管理 
实例 624 ”订单 信息 管理 . 
15.14 通用 信息 管理 … 
实例 625 “新闻 公告 管理 . 


诬 
镍 


基础 篇 


mm 第 1 章 开发 环境 
Wm 第 2 章 PHP 基础 
MW 第 3 章 Web 页 面 交互 


ss 


开发 环境 
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1.1 AppServ 一 一 PHP 集成 化 安装 包 


AppServ 将 Apache、PHP、MySQL 和 phpMyAdmin 等 服务 器 软件 和 工具 安装 配置 完成 后 进行 打包 处 理 ， 开 
发 人 员 只 要 到 网 站 上 下 载 该 软件 然后 安装 ， 即 可 完成 PHP 开发 环境 的 快速 搭建 ， 非 常 适合 初学 者 使 用 。 


> E 
初级 | 
实体 
实例 001 趣味 指数 : oboloioll 

图 实例 说 明 
在 本 实例 中 ， 讲 解 如 何 通过 AppServ 配置 PHP 的 开发 环境 ， 配 置 完成 后 将 出 现 如 图 1.1 所 示 对 话 框 。 
AppSerr 2.5.10 seue ‘=151x| 
Completing the AppServ 25 10 
Setup Wizard 
有 urrahbdooatiawead 
上 区 Eeepsee 
E W SartsQL 
[未 
口号 
oO: 
a 
EE [Be ] co 
图 1.1 通过 AppServ 配置 PHP 开发 环境 
图 关键 技术 


通过 AppServ 配置 PHP 开发 环境 时 ， 首 先 从 互联 网 上 下 载 AppServ 的 安装 文件 ， 下 载 地 址 为 
http://www.AppServnetwork.com/。 


< 注意 : 在 使 用 AppServ 搭建 PHP 开发 环境 时 ， 必 须 确保 在 系统 中 没有 安装 Apache、PHP 和 MySQL， 否 则 
要 先 将 这 些 软件 却 载 ， 然 后 应 用 AppServ。 


在 软件 的 安装 过 程 中 ， 要 重点 注意 下 面 几 个 步骤 
设置 安装 路 径 。 

选择 安装 软件 。 

设置 端口 号 。 

设置 数据 库 密码 。 

设置 数据 库 编码 格式 。 


图 设计 过 程 
下 面 对 应 用 AppServ 集成 化 安装 包 搭建 PHP 开发 环境 的 具体 操作 步骤 进行 讲解 。 


(1) 双击 AppServ-win32-2.5.10.exe 文件 ， 打 开 如 图 1.2 所 示 的 AppServ 启动 对 话 框 。 
(2) 单 击 图 1.2 中 的 Next 按钮 ， 进 入 如 图 1.3 所 示 的 AppServ 安装 协议 对 话 框 。 


图 网 轿 罗 加 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


Welcome to the AppServ 25 10 
Setup Wizard 


Tis wirerd wil guide you troush the nstelotien ofhopaerv 
Zs 


Tis reconmended thrat yo dose al other apoicasens 


图 1.2 AppServ 启动 页 面 图 1.3 AppServ 安装 协议 


(3) 单 击 I Agree 按钮 ， 进 入 如 图 1.4 所 示 的 对 话 框 ， 在 其 中 设置 AppServ 的 安装 路 径 〈 默 认 安 装 路 径 一 
般 为 CAppServ) ，AppServ 安装 完成 后 ，Apache、MySQL、PHP 都 将 以 子 目录 的 形式 存储 到 该 目录 下 。 
(4) 单 击 Next 按钮 ， 进 入 如 图 1.5 所 示 的 对 话 框 ， 在 其 中 选择 要 安装 的 程序 和 组 件 〈 默 认为 全 选 ) 。 


Select Components 
Seiect the components you Went soinatal, cear the compenents 
youdo rotwant io nstal, 


a 


可 


图 1.4 AppServ 安装 路 径 选择 图 1.5 AppServ 安装 选项 


_.GBg 技巧 : 在 第 (4) 步 中 ， 如 果 本 机 已 经 安装 MySQL 数据 库 ， 那 么 可 以 不 选中 MySQL Database 复 选 框 ， 仍 
使 用 本 机 已 经 存在 的 MySQL 数据 库 。 

(5) 单 击 图 1.5 中 的 Next 按钮 ， 进 入 如 图 1.6 所 示 的 对 话 框 ， 在 其 中 填写 计算 机 名 称 、 添 加 邮箱 地 址 、 设 

置 Apache 的 端口 号 (默认 为 80 端口 ) 。 


tp 
Acache HTTP Server riomation 
Pease eter you servers nomator 


1.6 ”Apache 端口 号 设置 
< 注意 : Apache 服务 器 端口 号 的 设置 ， 直 接 关系 到 Apache 服务 器 是 否 能 够 正常 启动 。 如 果 本 机 中 的 80 端口 


被 IIS 或 者 迅雷 占用 ， 那 么 这 里 就 需要 修改 Apache 的 端口 号 ， 或 者 修改 IIS 和 迅雷 的 端口 号 ， 这 样 
才能 完成 Apache 服务 器 的 配置 。 如 果 出 现 端口 冲突 ， 那 么 将 导致 安装 失败 ，Apache 服务 不 能 启动 。 
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(6) 单 击 Next 按钮 ， 进 入 如 图 1.7 所 示 的 对 话 框 ， 在 其 中 设置 MySQL 数据 库 root 用 户 的 登录 密码 及 字符 集 。 


[ED 说 明 : MySQL 数据 库 的 字符 集 ， 可 以 设置 为 UTF-8、GBK 或 者 GB2312 格式 。 这 里 将 字符 集 设置 为 GB2312 
Simplified Chinese， 表 示 MySQL 数据 库 的 字符 集 将 采用 简体 中 文 形式 。 


Er 


SN MSQL Server Contguraton 
Corfere he MySQL sever matonee, 


MySQL 
Pease erter Reotpesererd to Mysa see 
Ee rotpeseers 
一 2 
ss | 


| 
图 1.7 设置 MySQL 数据 库 root 用 户 的 密码 和 字符 集 


GBS 技巧: 对 于 在 图 1.7 中 设置 的 MySQL 数据 库 root 用 户 的 密码 必须 牢记 ， 因 为 程序 在 连接 数据 库 时 必须 使 
用 这 个 密码 。 建 议 读者 将 这 个 密码 设置 为 111, 因为 这 是 在 开发 本 书 中 的 程序 时 所 使 用 的 数据 库 密 码 。 
如 此 ， 在 运行 本 书 中 的 数据 库 程 序 时 ， 就 不 需要 修改 密码 ， 否 则 要 修改 连接 数据 库 的 密码 。 如 果 忘 
记 安 装 时 设置 的 密码 ， 最 直接 有 效 的 解决 方式 是 重新 安装 AppServ。 
(7) 单 击 Install 按钮 开始 安装 ， 如 图 1.8 所 示 。 
(8) 安装 完成 后 可 以 在 开始 菜单 的 AppServ 相关 操作 列表 中 启动 Apache 及 MySQL 服务 ， 如 图 1.9 所 示 。 


Completing the AppServ 2.5.10 
izard 


p 
户 | ing 
ER WW startMysQL 
上 妹 
有 

SS 
BN 

Meat neal sysien yin Ee 
ee [em ] ce 
图 1.8 AppServ 安装 页 面 1.9 AppServ 安装 完成 页 面 


国 秘笈 心 法 


心 法 领悟 001: Apache 的 配置 文件 。 
Apache 的 配置 文件 存储 于 C:\AppServ\Apache2.2\conf\httpd.conf。 通过 Apache 配置 文件 可 以 设置 Apache 的 
端口 号 、Apache 服务 器 的 根 目 录 或 者 控制 Apache 是 否 支 持 伪 静态 。 
(1) 设置 Apache 的 端口 号 : 


Listen 80 


(2) 设置 Apache 服务 器 的 根 目录 : 


DocumentRoot "C:/AppServ/www" 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
(3) 设置 对 伪 静 态 的 支持 : 
机 oadModule rewrite_module modules/mod rewrite.so 
将 该 项 前 面 的 “#” 去 掉 ， 可 启动 该 项 。 查 找 httpd.conf 文件 ， 找 到 其 中 的 AllowOverride 项 ,将 其 值 都 修改 
为 All。 
完成 对 Apache 的 修改 后 ， 必 须 保存 文件 ， 并 重新 启动 Apache 服务 器 才能 够 生效 。 
中 级 


ey 
| 
实例 002 地 呆 指 数 : 友 刘 克 


力 实例 说 明 
安装 AppServ 后 ， 可 以 对 其 进行 测试 。 在 正 浏览 器 的 地 址 栏 中 输入 hppt/127.0.0.1， 如 果 输 出 如 图 1.10 所 
示 的 页 面 ， 则 说 明 PHP 开发 环境 配置 成 功 。 


文件 归 镜 笛 于 查看 中 和 工具 四 一 帮 动 咱 
ER 


The AppServ Open Project - 2.5.10 for Windows 


误 phpMyAdmin Database Manaqer Version 2.10.3 
划 PHP Information Version 5.2.6 


10 0r 
AppSev is a merging opan source sowere installer packace fcr Windows 
incudos， 


» Apache Web Server Version2.28 

» PHP Script Language Velson 5.2.6 

» MySQL Database Version5.0.51b 

» phpMyAdmin Datebase Manegor Vorcion 2.10.3 


图 1.10 PHP 开发 环境 配置 成 功 


图 关键 技术 


AppServ 安装 完成 后 ， 整 个 目录 默认 安装 在 C:\AppServ 下 ， 此 目录 下 包含 4 个 子 目录 ， 如 图 1.11 所 示 ， 用 
户 可 以 将 所 有 程序 文件 存储 到 www 目录 下 。 


忌 

图 加 Mpache2.2 psche 的 存储 目录 

昌 自 Ws Mysql 的 存 绪 目录 

旬 昌 pho5 PIE 的 存储 路 径 

田 自 mw 网 页 文件 及 phpliyhdnin 的 存储 路 径 


1.11 AppServ 目录 结构 


在 Apache2.2\conf\ 目 录 下 ， 有 一 个 httpd.conf 文件 ， 它 是 Apache 服务 器 的 配置 文件 ， 在 这 个 文件 中 可 以 修 
改 Apache 服务 器 的 端口 号 、 根 目录 等 ， 所 有 有 关 Apache 服务 器 的 配置 都 在 这 个 文件 中 完成 。 

在 MySQL 目录 下 ， 有 一 个 my.ini 文件 ， 它 是 MySQL 服务 器 的 配置 文件 ， 存 储 MySQL 的 配置 信息 。 

在 MySQL\data 目录 下 存储 的 是 数据 库 文件 ， 所 有 程序 使 用 的 数据 库 都 存储 在 这 个 文件 夹 下 。 


[ED 说 明 : 如 果 MySQL 服务 器 的 版 本 是 5.1， 那 么 数据 库 文件 天 data 的 默认 存储 位 置 是 C:\Documents and 
Settings\All Users\Application Data MySQL\IMySQL Server 5.1\Data\。 


在 php5\ext 文件 夹 下 存储 的 是 PHP 内 置 的 函数 类 库 ， 以 .dll 的 格式 存储 ,而 PHP 的 配置 文件 php.ini 存储 在 
本 机 系统 盘 的 Windows 文件 夹 下 。 
www 目录 是 程序 运行 的 根 目 录 ， 也 就 是 说 我 们 要 运行 的 所 有 程序 都 必须 存储 在 这 个 目录 下 。phpMyAdmin 
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图 形 化 管理 工具 默认 存储 在 此 目录 下 。 
图 设计 过 程 
(1) www 文件 夹 存储 网 站 的 运行 文件 ， 其 默认 的 内 容 如 图 1.12 所 示 。 
ET ET | 站 
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图 1.12 www 文件 夹 的 默认 内 容 


(2) 其 中 ,index.php 是 默认 访问 127.0.0.1 时 浏览 的 内 容 ; 而 phpinfo.php 存储 的 是 PHP 的 配置 信息 和 支持 
的 模块 。phpinfo.php 的 内 容 如 图 1.13 所 示 。 


System 多 
Build Date |Nov 20 2009 17:20:57 

Compiler Isvc6 (Vsual C++ 6.0) 

Architecture bas 

Conngure Command |cscrpt Inclogo confgure 5 -enable-snapshotbuld 

Server APT |apache 20 Hander 

Virtual Directory Support |enabed 


1.13 phpinfo.php 的 内 容 
(3) 其 中 的 phpMyAdmin 文件 夹 存储 的 是 phpMyAdmin 图 形 化 管理 工具 。 
国 秘笈 心 ; 
心 法 领悟 002: AppServ 的 相关 说 明 。 
(1) 如 果 是 应 用 AppServ 配置 的 PHP 开发 环境 ， 那 么 在 IE 浏览 器 中 直接 输入 127.0.0.1 将 输出 如 图 1.10 
所 示 的 页 面 ， 因 为 在 www 文件 夹 下 有 一 个 默认 的 index.php 文件 ， 如 果 要 运行 www 文件 夹 下 的 其 他 文件 ， 那 
么 必须 在 127.0.0.1 后 指定 具体 的 文件 夹 或 者 文件 ， 例 如 ， 输 入 127.0.0.1/text.php 或 者 127.0.0.1/mr/。 
(2) Apache 的 启动 和 停止 。 
单 击 “ 开 始 ”按钮 ， 选 择 “ 程 序 ”/AppServ/Control Server by Service 命令 ， 在 弹出 的 菜单 中 完成 Apache、 
MySQL 服务 器 的 启动 和 停止 操作 。 
单 击 “ 开 始 ”按钮 ， 选 择 “ 设 置 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ”命令 ,找到 Apache 2.2， 右 击 , 在 
弹出 的 快捷 菜单 中 完成 Apache 的 启动 、 停 止 或 者 重新 启动 操作 。 
完成 对 php.ini 文件 的 修改 后 ， 同 样 要 保存 文件 ， 重 新 启动 Apache 服务 器 后 ， 修 改 才 能 够 生效 。 


De 
一 初级 
实例 003 趣味 指数 : , 
国 实例 说 明 


AppServ 安装 、 调 试 成 功 后 ， 开 发 第 1 个 PHP 程序 ， 输 出 系统 的 当前 时 间 ， 运 行 结果 如 图 1.14 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


文 作品。 二 沁 中 ”查看 WD 中京 中 IROD ”| 鄞 | 


Enrol EE 
EE| 
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图 二 [| OT 4 
图 1.14 第 1 个 PHP 程 序 


图 关键 技术 
(1) 应 用 PHP 中 的 date0 函 数 ， 输 出 系统 的 当前 时 间 ， 设 置 时 间 的 格式 为 年 -月 -日 时 :分 : 秒 (Y-m-d H:i:s〉。 
(2) 将 编写 的 index.php 文件 存储 于 www 文件 夹 下 的 MR\01\003 目录 下 。 
在 运行 本 实例 时 , 会 发 现 程 序 输出 的 时 间 与 系统 的 当前 时 间 相 差 了 8 个 小 时 ，, 至 于 为 什么 会 出 现 此 种 情况 ， 
将 在 本 实例 的 秘笈 心 法 中 讲解 。 


图 设计 过 程 
(1) 通过 Dreamweaver 创建 一 个 index.php 脚本 文件 ， 存 储 于 MR/01/003/ 文 件 夹 下 。 
(2) 应 用 date0) 函 数 输出 系统 的 当前 时 间 ， 其 代码 如 下 : 


<2php 
echo date("Y-m-d H:i:s"); // 输 出 系统 的 当前 时 间 
> 
(3) 在 正 浏 览 器 的 地 址 栏 中 输入 http://127.0.0.1/mr/01/003/， 运 行 结果 如 图 1.14 所 示 。 
国 秘笈 心 法 


心 法 领悟 003: 对 于 系统 时 间 的 相关 说 明 。 

程序 输出 时 间 与 系统 当前 时 间 出 现 偏差 的 关键 是 php.ini 文件 的 设置 。 在 php.ini 文件 中 , 默认 设置 的 是 标准 
的 格林 威 治 时 间 ， 即 采用 的 是 英国 伦敦 时 间 ， 而 当地 时 间 是 北京 时 间 ， 所 以 会 出 现时 间 的 偏差 。 

PHP 的 配置 文件 存储 于 C:\Windows\php.ini 文件 中 。 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone =” 
选项 ， 去 掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当地 所 在 时 区 使 用 的 时 间 ， 即 可 统一 程序 输出 的 时 间 与 系统 当前 
的 时 间 。 


:date timezone = 
例如 ， 如 果 当 地 所 在 时 区 为 东 作 区， 那么 就 可 以 设置 date.timezone 的 值 为 PRC、Asia/Hong_ Kong、Asia/ 
Shanghai (上 海 ) 或 者 Asia/Urumqi (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


1.2 XAMPP 一 一 PHP 集成 化 安装 包 


XAMPP (Apachet+MySQL+PHP+Perl) 是 一 个 功能 强大 的 建站 集成 软件 包 , 可 以 在 Windows、Linux、Solaris 
这 3 种 操作 系统 下 安装 使 用 ， 支 持 多 种 语言 ， 包 括 英文 、 简 体 中 文 、 繁 体 中文 、 韩 文 、 俄 文 、 日 文 等 。 


| 
实例 004 初级 


趣味 指数 : fd 


图 实例 说 明 
XAMPP 是 一 个 易于 安装 且 包含 MySQL、PHP 和 Perl 的 Apache 发 行 版 。 安 装 成 功 后 的 运行 效果 如 图 1.15 
所 示 。 


第 1 章 开发 环境 


图 1.15 XAMPP 安装 成 功 


图 关键 技术 


目前 XAMPP 的 Windows 版 本 是 1.7.3， 包 括 如 下 内 容 : 
Apache 2.2.14 (IPv6 enabled) 

MySQL 5.1.41 + PBXT engine 

PHP 5.3.1 

OpenSSL 0.9.81 

phpMyAdmin 3.2.4 

XAMPP Control Panel 2.5.8 

XAMPP CLI Bundle 1.6 

Webalizer 2.21-02 

Mercury Mail Transport System v4.72 
msmtp 1.4.19 

FileZilla FTP Server 0.9.33 

SQLite 2.8.17 

SQLite 3.6.20 

ADOdb 5.10 

eAccelerator 0.9.6-rcl 

Xdebug 2.0.6-dev 

Ming 0.4.3 

适用 于 Windows 2000/XP/2003/Vista/7。 

在 Windows 操作 系统 下 ，XAMPP 有 两 种 形式 : 
回 自 解压 RAR 包 一 一 简单 且 安全 

加 ”ZIP 压缩 包 一 一 XAMPP 的 普通 ZIP 压缩 档案 


国 设计 过 程 


国共 因 因 因 办 因 办 因 因 因 因 办 办 办 办 


加 


PHP 开发 实例 大 全 (基础 卷 ) 


XAMPP 1.7.3 版 的 具体 安装 步骤 如 下 : 
(1) 运行 .exe 安装 文件 ， 弹 出 如 图 1.16 所 示 对 话 框 ， 在 这 里 设置 XAMPP 的 安装 路 径 。 
(2) 安装 路 径 设 置 完成 后 ， 单 击 Install 按钮 ， 执 行 XAMPP 的 安装 ， 如 图 1.17 所 示 。 


而 XAMpp for wndows iE] 而 XAMPP for Windows [ef]| 


® Press Install button to start extraction 加 
。 Use Browse button to select tiration folder 
Xx from the folders tree. lt can bi red manually X 


Ifthe destination folde 
created automatically 


exist, it will be 
extraction 


。 After extraction, the setup script 


» To install semices or start/stop tI 
the XAMPP Control Panel 


| 习 
Dearaonfoaer 
全 | 


Instalation progress 


Destination folder 


Installation progress 
[ 


aa rea EE 
图 1.16 设置 XAMPP 的 安装 路 径 图 1.17 安装 XAMPP 


(3) XAMPP 安装 成 功 后 ， 将 弹出 如 图 1.18 所 示 的 操作 界面 ， 在 其 中 对 XAMPP 进行 设置 ， 包 括 是 否 创建 
桌面 快捷 方式 、 是 否 在 开机 时 启动 XAMPP 等 。 


着 


提 提 提 和 持 捍 持 提 提 和 持 捍 持 持 持 提 捍 捍 提 和 持 持 持 提 和 和 和 提 和 和 拉 持 和 拉 和 持 和 持 拉 拉 和 持 失 失 持 持 拉 提 持 持 提 拉 挂失 拉 和 和 


ight 2889 Carsten Wiednann 《P sD License) 
ten Wiednann <carsten_sttgtegnx -de 
ge lgesang 《kuoBapachefrien 


TT TT 


Control Panel 


图 1.18 设置 XAMPP 


至 此 ，XAMPP 安装 、 配 置 完 毕 。 
图 秘笈 心 法 
心 法 领悟 004: XAMPP 中 的 配置 文件 。 
XAMPP 中 各 种 配置 文件 的 存储 位 置 如 下 。 
Apache 基本 配置 : .\xampp\apache\conf\httpd.conf。 
Apache SSL: .\xampp\apache\conf\ssl.conf。 
Apache Perl 〈 仅 限 插件 ) : .\xampp\apache\conf\perl.conf。 
PHP: .\xampp\php\php.ini。 
MySQL: .\xampp\mysql\bin\my.ini。 
phpMyAdmin: .\xampp\phpMyAdmin\config.inc.php。 


因 办 办 办 办 办 
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FileZilla FIP 服务 器 : \xampp\FileZillaFTP\FileZilla。 


初级 
趣味 指数 : 请 博 去 家 


实例 005 


力 实例 说 明 


成 功 安装 XAMPP 后 ， 启 动 Apache 服务 器 ， 在 浏览 器 的 地 址 栏 中 输入 http://localhost 或 http://127.0.0.1， 
即 可 检测 所 有 的 XAMPP 样 例 和 工具 ， 运 行 结果 如 图 1.19 所 示 。 


图 1.19 检测 安装 是 否 成 功 
图 关键 技术 


XAMPP 中 默认 将 所 有 网 络 文档 存储 于 htdocs 主 文件 夹 中 〈.\xampp\htdocs) 。 默 认 htdocs 主 文件 夹 下 的 内 
容 如 图 1.20 所 示 。 


ET ET 
WE [DO (wpe stds: EE 
[Em 7 1 [ss 7 | 


图 1.20 XAMPP 的 默认 网 络 文件 
读者 可 以 在 浏览 器 的 地 址 栏 中 输入 http://localhost/ 来 检测 XAMPP 是 否 安装 成 功 。 
力 设计 过 程 


(1) XAMPP 文件 夹 存储 的 是 XAMPP 的 各 种 配置 信息 , 当 直 接 运 行 index.php 文件 时 ,调用 的 就 是 XAMPP 
文件 夹 下 的 index.php 文件 ， 输 出 如 图 1.20 所 示 的 内 容 。 


(2) 在 index.html 文件 中 ， 输 出 一 个 简单 的 测试 信息 ， 如 图 1.21 所 示 。 


外 
让 WW 于 ws/ on Vics tw 可 加 RSS 


It works! 引 
BE [| Oa 


加 


PHP 开发 实例 大 全 (基础 卷 ) 
图 1.21 通过 HTML 测试 PHP 是 否 安装 成 功 
(3) 在 index.php 文件 中 , 通过 header0 函 数 跳 转 到 xampp 文件 夹 下 的 index.php 文件 , 输出 XAMPP 的 信息 。 


心 法 领悟 005: 启动 、 停 止 和 测试 XAMPP。 
通过 文件 xampp\xampp-control.exe 控制 XAMPP 的 启动 、 停 止 和 测试 。 


力 实例 说 明 
XAMPP 只 为 开发 者 服务 , 切记 不 要 将 其 应 用 于 生产 环境 ,因为 对 于 生产 环境 而 言 , 使 用 XAMPP 可 能 会 带 
来 灾难 性 的 打击 。 
因为 MySQL 管理 员 (root) 未 设置 密码 ， 用 户 可 以 直接 通过 phpMyAdmin 访问 MySQL 服务 器 ， 修 改 数据 
库 中 的 数据 ， 或 者 通过 网 络 访问 ， 运 行 结果 如 图 1.22 所 示 。 
ETIIIEITIITTTTIPTTTTEEZEDECOOOOS 


文件 四 ”编辑 EE) 查看 W) 收 豪 4) 工具) 而 | 3 
矶 本 WW [ 轩 htts /1127 0 0 Uphpeysinin/index php7ab=cdcolttoken-os02bce dud2 7] 区 和 到 | 访 按 | 


全 图 加 


数据 库 
phpmyadmin 加 了 


phpmyadmin (8) F bookmark 办 同 缮 而 Xs 
Ee PE il 


[TT [| (Ons 四 


1.22 直接 访问 MySQL 数据 库 


图 关键 技术 


要 确保 MySQL 数据 库 的 安全 ， 必 须 为 MySQL 管理 员 (root) 设置 密码 ， 其 方法 如 下 : 
以 root 用 户 的 身份 登录 phpMyAdmin， 在 phpMyAdmin 的 权限 中 设置 root 用 户 的 密码 。 操 作 界面 如 图 1.23 
所 示 。 


中 服务 器 : localhost 
_ 而 数据 话 “. 丸 SQL 间 状 态 ” 同 变 重 。[ 且 字符 集 “ 甩 引 学 、 全 权限 _ 忽 进 程 ”总 导出 防 导 入 
多 编辑 权限 : 用 户 roor'@'ocalhost 
广 售 改 室 妈 
7 天 
oes ep 
室 码 加 密 方式 。 G MySQL 4 1+ 

人 羔 客 MysQL40 


生成 室 码 E23| EE 一 | 


图 1.23 修改 MySQL 用 户 密码 
[| 说 明 : 更 改 root 的 密码 之 后 ， 还 要 修改 phpMyAdmin 中 的 相关 信息 ， 具 体 方法 请 参看 设计 过 程 。 


第 1 章 开发 环境 


图 设计 过 各 

在 phpMyAdmin 的 权限 中 完成 root 用 户 的 密码 设置 后 , 在 .xampp\phpmyadmin\ 下 搜索 config.inc.php 文件 ， 
定位 到 如 下 位 置 : 

/* Authentication type and info */ 

$cfg['Servers][$il['auth_type] = ‘http'; /设置 登录 方式 

$cfg['Servers'][$il[user] = root: /设置 用 户 名 

$cfe['Servers'][$il[password]= "111; /设置 密码 


Scfel'Servers'][Si][AllowNoPassword'] = true; 
设置 auth_type 的 值 为 “http”; 设置 password 的 值 为 “111”， 这 样 登录 phpMyAdmin 时 ， 就 必须 要 输入 
密码 ， 否 则 无 法 登录 。 


国 秘 稚 心 法 


心 法 领悟 006: 修改 MySQL 默认 字符 集 。 
修改 MySQL 默认 字符 集 为 utf8， 定 位 到 my.ini 文件 ， 需 添加 如 下 内 容 : 


[client] 
default_character set=utf8 
[mysqld] 

# default-character-set=utf8 
character-set-server = utf8 
collation-server = utf8_general_ci 
[mysql] 
default_character_set=utf8 


初级 
趣味 指数 : holed 
实例 说 明 


既然 XAMPP 只 为 开发 者 服务 ， 那 么 我 们 就 应 用 XAMPP 开发 一 个 PHP 程序 ， 熟 悉 一 下 XAMPP 的 应 用 。 
本 实例 简单 地 输出 一 段 文字 ， 其 运行 结果 如 图 1.24 所 示 。 


可 第 二 个 PiT 程 床 -Wiecrese EEC 
文件 四 ”编辑 E) 查看 W) 收藏 A) 工具 QD) 


奸 古 如 [站 http //127.0.0. 1/or/01/007/ 司 回 和 3 全 
现在 是 ，2010 年 06 月 28 日 05 时 24 分 31 秒 
局 大 [ 厂 [ [后 有 


Sl tels a 


图 1.24 第 2 个 PHP 程 序 


力 关键 技术 


(1) 确定 服务 器 的 运行 文件 夹 ， 编 写 PHP 脚本 文件 ， 将 其 存储 于 XAMPP 指定 的 运行 文件 夹 下 。 
(2) 应 用 PHP 的 date0 函 数 输出 系统 的 当前 时 间 ， 时 间 的 格式 是 “年 月 日 时 分 秒 ”。 


国 设计 过 程 
(1) 新 建 一 个 记事 本 文件 ， 编 写 PHP 脚本 ， 通 过 date0 函 数 输出 系统 的 当前 时 间 ， 其 代码 如 下 : 
a "date("Y 年 m 月 d 日 了 时 i 分 s 秘 "); 


13 


PHP 开发 实例 大 全 (基础 卷 ) 


(2) 保存 这 个 记事 本 文件 ， 将 其 存储 于 xampp\htdocs\MR\01\007〈 这 是 笔者 在 本 机 中 定义 的 实例 存储 文 
件 夹 ) 。 


图 秘笈 心 法 

心 法 领悟 007: 配置 默认 的 开始 页 面 。 

如 果 在 浏览 器 地 址 栏 中 输入 http://localhost/xampp/, Apache 服务 器 会 自动 返回 一 个 默认 的 开始 页 面 , Apache 
会 自动 寻找 已 存在 的 类 似 index.php 的 索引 页 。httpd.conf 中 的 DirectoryIndex 指令 负责 这 个 功能 。 在 这 里 可 以 
定义 默认 开始 页 面 的 名 字 和 协议 。 


XAMPP 在 默认 状态 下 ，DirectoryIndex 指令 的 列表 如 下 : 
index php index php4 index:php3 index.cgi index.pl index.html indexhtm index htmlvarindex phtml 


1.3 IIS+PHP+MySQI 一 一 独立 搭建 PHP 开发 环境 


Intemet 信息 服务 器 即 Internet Information Server, 缩写 为 TS, 是 Microsoft 的 Web 服务 器 。 它 集成 于 Windows 
NT Server 之 中 ， 方 便 易 用 ， 为 Web 应 用 程序 提供 了 功能 强大 的 运行 平台 。 

本 书 使 用 IS 6.0， 在 Windows 2003 操作 系统 下 完成 PHP 环境 的 搭建 ， 所 使 用 的 软件 如 下 。 

加 ”PHP 软件 : php-5.3.1-nts-Win32-VC9-x86。 

加 ”MySQL 数据 库 : mysql-essential-5.1.39-win32.msi。 


| 说 明 : 上 述 版 本 是 笔者 所 使 用 的 ， 读 者 可 以 根据 自己 的 实际 情况 进行 调整 。 如 果 是 Windows 7 操作 系统 ， 
则 使 用 IS 7.0， 如 果 是 Windows XP 系统 ， 则 使 用 IIS 5.0。 


实例 008 趣味 指教 : 请 请 良家 | 


实例 说 明 


PHP 5.3.1 是 使 用 较 多 的 版 本 , 读者 可 以 到 PHP 的 官方 网 站 下 载 , 下 载 地 址 为 http://www.php.net/ downloads. php。 
本 实例 讲解 如 何 选择 、 安 装 PHP 5.3.1。 


力 关键 技术 


(1) 版 本 的 区 分 。PHP 推出 的 PHP 5.3.1 有 多 个 版 本 ， 包 括 VC6、X86 和 VC9、X86。 
回 VC 6: legacy Visual Studio 6 compiler， 是 使 用 此 编译 器 编译 的 。 
VC 9: the Visual Studio 2008 compiler， 是 用 微软 的 VS 编辑 器 编译 的 。 
(2) 版 本 的 选择 。 
如 果 在 Windows 下 使 用 Apache+PHP， 选 择 VC 6 版 本 ; 
如 果 在 Windows 下 使 用 IS+PHP， 选 择 VC 9 版 本 。 
(3) Non Thread Safe 和 Thread Safe。Non Thread Safe 是 非 线 程 安全 ;Thread Safe 是 线程 安全 。 官 方 不 建 
议 将 Non Thread Safe 应 用 于 生产 环境 ， 所 以 我 们 选择 Thread Safe 版 本 的 PHP。 


图 设计 过 程 
下 面 讲解 php-5.3.1-nts-Win32-VC9-x86 的 配置 方法 。 
(1) 将 下 载 的 文件 php-5.3.1-nts-Win32-VC9-x86.zip 解压 ， 重 新 命名 为 php， 并 将 其 复制 到 指定 的 目录 下 。 
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例如 C:\php、F:\php 等 。 这 里 将 php 放置 在 F:\PkhiisPHP 目录 下 。 

(2) 将 F:\PkhiisPHP\php 目录 下 的 libMySQL.dll 文件 复制 到 C:\Windows\system32\( 如 果 是 Windows 2000， 
则 为 CA\WINNT\system32\) 目录 下 。 

(3) 将 F:\PkhiisPHP\php 目录 下 的 php.ini-development 重 命名 为 php.ini， 如 图 1.25 所 示 ， 并 将 其 复制 到 系 
统 盘 的 Windows 文件 夹 下 〈 例 如 ， 若 C 盘 为 系统 盘 ， 则 是 C:\Windows) 。 


EP 
名 恨 -间作 | 站 扫 案 己 XH | 加- 
地 址 ) | 咏 nT IEEIE 


文件 和 文件 卖 任务 php.gf 3X5 GF 图 人 
本 ni 9 KS 配置 设置 
em | re 3 是 本 
php<gee 9S 应 用 程序 
合格 寺 择 的 项 目 发 布 到 配 womee Ja 应 用 程序 下 
@ ed EN puns-phosco.reg 1K8 注册 表 项 > 
所 项目 zl a "i 


辽 定 2 个 对 象 人 


图 1.25 生成 php.ini 


(4) 打开 php.ini 文件 并 定位 到 extension_dir="./" 这 一 行 ， 修 改 为 extension_dir=" F:\PkhiisPHP\php\ext"。 
(5) 同样 在 php.ini 文件 中 ， 将 下 面 5 项 设置 前 的 分 号 去 掉 ， 并 设置 相应 的 参数 ， 完 成 对 CGI 和 FastCGI 


et 

:cgirfe2616_headers = 1 

(6) 加 载 动态 库 。 例 如 ， 定 位 到 :extension=php_MySQL.dll 这 一 行 ， 将 前 面 的 分 号 “:” 去 掉 ， 完 成 MySQL 
动态 库 的 加 载 。 

(7) PHP 安装 成 功 后 ， 还 要 对 FastCGI 进行 配置 ， 在 系统 盘 的 \system32\inetsrv\ 文 件 夹 下 找到 fcgiext.ini 文 
件 ， 在 该 文件 的 最 后 添加 如 下 内 容 : 


[Types] 

Php=PHP 

[PHP] 
ExePath=F:\PkhiisPHP\php\php-cgi.exe 


其 中 ，[Types] 指 定语 言 为 PHP; [PHP] 指 定 php-cgi.exe 在 本 机 中 的 安装 位 置 。 
国 秘笈 心 法 

心 法 领悟 008: 使 用 IS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 。 

如 果 使 用 IS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 ,那么 本 机 中 必须 安装 微软 的 VC++ 2008(Visual C++ 2008， 
简称 VC++ 2008) 的 运行 库 (veredist_x64.exe 或 者 vcredist x86.exe) 和 FastCGI 扩 展 〈fegisetup32.msi) ， 以 确 
保本 机 的 IS 6 支持 FastCGI。 


初级 


实例 009 趣味 指数 : | 
实例 说 明 


MySQL 是 目前 最 为 流行 的 开放 源码 的 数据 库 , 是 完全 网 络 化 的 跨 平 台 的 关系 型 数据 库 系统 。 它 是 由 MySQL 
AB 公司 开发 、 发 布 并 支持 的 。 任 何人 都 能 从 Intermet 上 下 载 MySQL 软件 ， 并 且 不 需 支 付 任何 费用 。 


PHP 开发 实例 大 全 〈 基 础 老 ) 
在 MySQL 的 官方 网 站 (http://www.mysql.com) 中 可 以 下 载 到 最 新 版 本 的 MySQL 服务 器 。 
图 关键 技术 
在 MySQL 的 官方 网 站 (http://www.mysqlcom) 中 下 载 最 新 版 本 的 MySQL 服务 器 的 具体 步骤 如 下 : 
(1) 打开 正 浏览 器 ， 在 地 址 栏 中 输入 http://www.mysql.com， 进 入 MySQL 的 官方 网 站 ， 如 图 1.26 所 示 。 


图 World s most popular open Source ase 一 Nicre: TInternet Ter 


立 件 们 ”编辑 已) 查看 忆 半 他 工具 人 必 币 如 E23 
9 A 豆 
-日 -着 国 入 | 用 寻 克 x 如 | 仿 - 总 国 
地 直 四 图 Nt: msl cn/ € ME ue* 
a 


AN (BUN "acommended oervers tor mont 
MySQL ) 


The world's most popular open source database 


Inside 


Get the Guide 


(2) 单 击 Downloads 超 链 接 ， 进 入 
文件 中 天 EE 二 Bb 
Oi 日 国 国 移 记 es 实 eex 加 全 :和 局 司 
HE 加 | 手 Mtp://dv wag con/ towndonts 

UC TT 
MySQL ) he i 


3B Solutions ¥ Customer Louin 


Loon | Reoister | 


MySQL Downloads 


MySQL Downloads 
* MySQL software is provided under the GPL License 
» OEMs, ISVs and VARS can purchase Commercial Licenses 


Contact Sales * Learn about MySQL Products and MySQL Services 
UsA Tol Free: +1.386-221-0834 
USA - From abroacs 单 击 超 链接 ， 下 载 MySQL CommunityServer 
+1-208-327-6494 

USA -Suesenpaon Ronewakc; 
OR: Important Platform Support Updates » 


Latin America: +1 512 535 7751 
Us +44 845 359 1124 MySQL Community Server 
reland: +353 1 6919191 

Germany: +ag 99 420 95 99 95 


Current Release (Recommended) 


图 1.27 MySQL Downloads 页 面 
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(3) 单 击 MySQL 5.1 一 Generally Available (GA ) release for production use 超 链接 , 进入 MySQL Connumity 
Server 下 载 页 面 ， 如 图 1.28 所 示 。 


5 了 
ETE TE 

Be- 日 国 国 竹本 去 ex 加 辐 - 癌 蕊 
Tr 


yo Downloads 


» MySQL software is provided under the GPL License 引 


> OEMs, ISVs and VARs can purchase Commercial Licenses 


Products and MySQL Services 
单 击 下 载 按钮 


UEA -Tol Free: +1.866-221-0534 


VEA -From abroad Wo cone fowly avalable 0 
Uist price (US) pe Seartng af $599/sorveryear 
+1-208-327-6404 under the GRL License sl EE 


Orman 


图 1.28 MySQL Connumity Server 下 载 页 面 
(4) 单 击 Download 按钮 ， 进 入 如 图 1.29 所 示 页 面 。 在 该 页 面 中 ， 可 以 选择 安装 的 平台 。 


四 | ESEEE 
ET [3 
@ 右 -日 ,四 国 的 让 晤 次 ex 如 | 全 -总 现 
区 TO 


MySQL 
Newsletter 


Cv 人 


MySQL Community Edit 


downioadab version of the worid's most popular open source 


= 
acabase that ls supported by an actVs community of open source dovelopars and enthuslacts, 


avalable as 3 separate download, The reason for 
er can provide more frequent updates and 5upport 


ve to our Bugs Database, Thank you for your 


SL Ust of changss 
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图 1.29 选择 安装 的 平台 


(5) 这 里 选择 Windows 平台 ， 单 击 Windows 超 链接 ， 进 入 如 图 1.30 所 示 的 页 面 。 在 该 页 面 中 ， 可 以 下 载 


不 同安 装 方式 的 MySQL。 
(6) 单 击 Windows Essentials(x86) 后 面 的 Download 超 链接 , 将 弹出 下 载 对 话 框 , 在 该 对 话 框 中 单 击 “ 保 存 ” 


按钮 ， 下 载 Windows 安装 版 的 MySQL。 


[ED 说 明 : (1) 如 果 在 该 页 面 中 没有 出 现 Download 超 链接 ， 可 以 单 击 Pick a mirror 超 链接 ， 选 择 一 个 镜像 进 
行 下 载 。 

(2) 本 书 在 讲解 MySQL 的 下 载 和 安装 时 使 用 的 是 mysql-essential-5.1.39 版 本 ， 当 读者 看 到 本 书 时 ， 

这 个 版 本 可 能 不 是 最 新 的 版 本 了 。 不 过 MySQL 的 下 载 和 安装 步骤 基本 没有 变化 ， 读 者 仍然 可 以 使 
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用 本 书 中 提供 的 步骤 、 方 法 进行 下 载 和 安装 。 
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图 1.30 MySQL 的 下 载 列表 


图 设计 过 程 
下 面 讲解 MySQL 的 具体 安装 步骤 。 

(1) 双击 下 载 后 的 mysql-essential-5.1.39-win32.msi 文件 ， 打 开 安 装 向 导 对 话 框 ， 单 击 Next 按钮 后 ， 进 入 
Setup Type (选择 安装 类 型 ) 对 话 框 。 在 该 对 话 框 中 ， 共 包括 Typical (典型 )、Complete 完全) 和 Custom ( 自 
定义 ) 3 种 安装 类 型 。 这 里 选择 典型 安装 ， 如 图 1.31 所 示 。 

(2) 单 击 Next 按钮 ， 打 开 准 备 安装 对 话 框 ， 在 该 对 话 框 中 将 显示 默认 的 安装 路 径 ， 单 击 Install 按钮 ， 开 
始 安装 MySQL。 在 安装 的 过 程 中 ， 将 显示 MySQL Enterprise 的 宣传 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 
进入 下 一 个 宣传 对 话 框 ， 再 次 单 击 Next 按钮 ， 将 进入 如 图 1.32 所 示 的 Wizard Completed (成 功 向 导 ) 对 话 框 。 
在 该 对 话 框 中 采用 默认 设置 ， 单 击 Finish 按钮 ， 继 续 安装 MySQL 服务 器 。 
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图 1.31 选择 安装 类 型 对 话 框 图 132 成 功 向 导 对 话 框 


(3) 这 时 将 进入 欢迎 安装 MySQL 服务 器 的 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 进 入 如 图 1.33 所 示 
的 MySQL 服务 器 配置 类 型 对 话 框 。 在 该 对 话 框 中 可 以 选择 详细 配置 或 者 标准 配置 ， 这 里 选择 详细 配置 。 

(4) 单 击 Next 按钮 ， 进 入 如 图 1.34 所 示 的 选择 服务 器 类 型 对 话 框 。 在 该 对 话 框 中 将 提供 开发 者 类 型 、 服 
务 器 类 型 和 致力 于 MySQL 服务 类 型 。 这 里 选择 默认 的 开发 者 类 型 。 

(5) 单 击 Next 按钮 ， 进 入 如 图 1.35 所 示 的 选择 数据 库 用 法 对 话 框 ， 在 该 对 话 框 中 提供 3 个 选项 ， 分 别 是 
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多 功能 型 (Multifunctional Database) 、 仅 提供 事务 型 (Transactional Database Only) 和 仅 不 提供 事务 型 


(Non-Transactional Database Only) 。 这 里 选择 多 功能 型 。 
(6) 单 击 Next 按钮 ， 进 入 如 图 1.36 所 示 的 设置 服务 器 安装 路 径 的 对 话 框 ， 这 里 采用 默认 设置 


本 5 Servor stace Contieuration Hird 3 因 


MySQL Server Instance Configuration 
Canfgua the SQL Servor .1 server ntanes, 


Mease sleet oconfiguration type, 


fF petailed Configuration 


D3 Choosethsconfouraticn type to create the ortimal server setup for 
hie machine 


Standard Confiouration 


rw 
nstalanon, Ths wil use 3 genera Purpose con6guration 
sorver hat can be tuned nanually. 


Ter uration 


MysQt server Inctance Configuration 


Confowre the msoL Saver 5.1 server irstarce, 


Tssacevebpment narhne, nd nany other spple ans Wil be 
各 mt no 


pease seedasere ype This wil hfuene merory, dikandCFUusage， 
Developer Machine 


Bere seryer phatens sl be rannng on this ahne Chocse 
this oplion for wetyapflication servers MySQL. willhave nedium 
memory erage, 


Dedicoted MySQL Server Mochine 
he machine i tedicatedto run the MYSQL Databace server No 


othe sarvers, uch 26 3 web or mal servar, wil be run, MySQL Nl 
wiee Pp tool eraloble menay, 


Cenfioure the Ws Server 5 sarver netancs, 


pu pose databases, This wh optmmige the server 


sarver for the um 
司 沾 Se mb 


the hoh peed 
Tronsoctional Dotabose Only 
品 Ootimieed for apoicaktbn servers and transartonal web aopications, 
Thie whl nake Inno the nan ctorage engine. Nobe th the 
MISAM ongine can cbll be uced, 
Non-Transactional Database Only 
Suikad Fer dmpls web scolc tiens, meritoing or pggng aorlicatione 


an Ch tne ror tancend VS 
sora engno wlbo oct ote 


me | mee] 


area 


el | | Ee| | 
图 1.33 MySQL 服务 器 配置 类 型 对 话 框 图 1.34 选择 服务 器 类 型 对 话 框 
i ep 


MySQt Server Inetance Configuration 
Confiowre be mWsoL Server 5.1 server hetanee, 


Mease seiect the drive fer the Immo0B datafie, f you do rot want to use the defadt settings, 
ITnnapB Tablespare Settings 


Please chonss the crive and drectory wnere the lrneD tatlespacs 
shouldbe plared. 


Ea rm | 
Drve Info- 


volume ae 
Me sysen: ms 


国 ksz ce cls toed D2 00 Fne Dnapee 


<pack [RE 


Corce 


图 1.35 选择 数据 库 用 法 对 话 框 


1.36 设置 服务 器 安装 路 径 对 话 框 


(7) 单 击 Next 按钮 ， 进 入 如 图 1.37 所 示 的 设置 提示 连接 的 数量 的 对 话 框 ， 这 里 采用 默认 设置 。 
(8) 单 击 Next 按钮 ， 进入 如 图 1.38 所 示 的 设置 网 络 选项 对 话 框 ， 在 该 对 话 框 中 采用 默认 设置 。 


MySQL Server Inctance Confiouration 
Cenfigure the M/S Sarver 1 cerver iretarce. 


Please sat the approvinate nmber cf cancunrent connectime to the cerver 


Salect hi plion For database appleabons that wl rok reqyire > 
numbor cf concurrark tonnectione A runbar of 20 cornections 
mil be assuned, 


三 Online Transaction Processing (OLTP) 
Choose this option for hichly concurrert applcauons that may have 
Seen ore Ine pto So eetve comectors nghas Peavh Daed 

Servers, 


Manual Satting 
Please erter the approdinatenunber of concunent connecicns. 


Cenaurent comnedtionst [5 司 


[ee ee 


MySQL server Inctance Configuration 
erfoure the MySQL Server £1 cerver iretaree, 


Enabie the to low TCP/P connacione, When deabled, only bcal 
omnecione through named ppes re slowed 


ratte IE 可 edfvonal excspacn or ths pert 


eaee cet tye netwrkng optiore. 


(7 Enable TEP/IP Networkang 


Mlease Set the server 3a ote. 
(7 Enable Strict Mode 


Ths option forces the seryer lo beheve more iks etadtbral 
Headase server, 6 reconmended to enable the option, 


el | er ek | 


图 1.37 设置 提示 连接 的 数量 的 对 话 框 


图 1.38 设置 网 络 选项 对 话 框 


Cg 技巧 MySQL 使 用 的 默认 端口 是 3306， 在 安装 时 ， 可 以 修改 为 其 他 的 ， 如 3307。 但 是 一 般 情 况 下 ， 不 要 
修改 默认 的 端口 号 ， 除 非 3306 端口 已 经 被 占用 。 
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(9) 单 击 Next 按钮 ， 将 打开 设置 默认 的 字符 集 的 对 话 框 ， 在 该 对 话 框 中 选中 Manual Selected Default 
Character Set/Collation 单 选 按钮 ， 并 在 Character Set (字符 集 ) 下 拉 列 表 框 中 选择 gbk (简体 中 文 ) ， 如 图 1.39 


所 示 。 


(10) 单 击 Next 按钮 ， 进 入 如 图 1.40 所 示 的 设置 Windows 选项 的 对 话 框 ， 这 里 采用 默认 设置 。 
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图 1.39 设置 默认 的 字符 集 对 话 框 


1.40 设置 Windows 选项 对 话 框 


(11) 单 击 Next 按钮 ， 进 入 安全 设置 选项 对 话 框 ， 该 对 话 框 用 于 为 默认 用 户 root 设置 密码 ， 这 里 设置 为 


111， 如 图 1.41 所 示 。 


(12) 单 击 Next 按钮 ， 进 入 准备 执行 对 话 框 ， 单 击 Execute 按钮 ， 完 成 服务 器 配置 ， 配 置 完成 后 ， 将 显示 
如 图 1.42 所 示 的 对 话 框 。 单 击 Finish 按钮 ， 完 成 MySQL 的 安装 。 
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1.41 ”安全 设置 选项 对 话 框 


图 1.42 ”完成 服务 器 配置 


[ED 说 明 : MySQL 安装 完成 后 ， 将 在 “开始 ”/“ 所 有 程序 ”菜单 下 添加 一 个 MySQL 项 ， 在 该 项 中 包括 一 个 
MySQL Server 5.1 子 项 ， 在 该 子 项 下 ， 又 包括 MySQL Command Line Client、MySQL Server Instance 
Config Wizard 和 SunInventory Registration 3 个 子 项 。 其 中 MySQL Command Line Client 为 MySQL 
的 客户 端 命令 行 ， 通 过 该 项 ， 可 以 查看 数据 表 结构 及 执行 SQL 语句 ; MySQL Server Instance Config 
Wizard 项 可 用 于 修改 MySQL 的 配置 ， 如 修改 字符 集 和 root 用 户 的 密码 等 。 


至 此 ，MySQL 安装 成 功 ， 如 果 要 查看 MySQL 的 安装 配置 信息 ， 可 以 通过 MySQL 安装 目录 下 的 my.ini 文 


件 来 完成 。 


在 my.ini 文件 中 ， 可 以 查看 到 MySQL 服务 器 的 端口 号 、MySQL 在 本 机 的 安装 位 置 、MySQL 数据 库 文件 
存储 的 位 置 ， 以 及 MySQL 数据 库 的 编码 等 配置 信息 ， 如 图 1.43 所 示 。 
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图 1.43 myini 文件 的 配置 信息 
秘笈 心 法 


心 法 领悟 009: 设置 MySQL 用 户 的 密码 。 


在 安装 MySQL 数据 库 时 ， 一 定 要 牢记 在 第 〈1) 步 中 设置 的 root 用 户 的 密码 ， 它 是 我 们 在 访问 MySQL 数 
据 库 时 必须 使 用 的 。 


初级 
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本 书 以 Windows 2003 中 使 用 的 IS 6.0 为 例 , 讲解 IS 的 安装 。 至 于 在 其 他 操作 系统 中 的 安装 步骤 是 相同 的 ， 
只 是 使 用 的 版 本 有 所 不 同 。 


图 关键 技术 


IIS 的 安装 非常 简单 ， 关 键 是 如 何 配置 IS 服务 器 。 
(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 中 双击 “管理 工具 ”图 标 ， 在 弹出 的 窗口 
中 单 击 “Internet 信息 服务 (IIS) 管理 器 ”图 标 ， 将 弹出 IS 管理 器 界面 ， 如 图 1.44 所 示 。 
(2) 图 中 的 “默认 网 站 ” 即 为 IS 服务 器 的 文件 目录 。 右 击 “ 默 认 网 站 ”， 在 弹出 的 快捷 菜单 中 选择 “ 属 
性 ”命令 ， 弹 出 “默认 网 站 属性 ”对 话 框 ， 可 在 其 中 设置 网 站 的 属性 ， 如 图 1.45 所 示 。 
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图 1.44 IIS 管理 器 界面 图 1.45 “默认 网 站 属性 ”对 话 框 
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(3) 默认 选中 的 是 “网 站 ”选项 卡 ， 在 其 中 可 以 设置 TCP 端口 号 ， 这 里 将 IS 端口 号 设置 为 “82”。 设 置 
完成 后 选择 “ 主 目录 ”选项 卡 ， 如 图 1.46 所 示 。 
(4) 在 “ 主 目录 ”选项 卡 中 进行 3 项 设置 : 第 1 项 是 设置 本 地 路 径 , 用 户 可 以 自行 定义 , 如 FAPkhiisPHP\www; 


第 2 项 是 设置 执行 权限 ， 这 里 设置 为 纯 脚本 ; 第 3 项 是 添加 PHP 的 支持 。 单 击 “ 主 目录 ”选项 卡 中 的 “配置 ” 
按钮 ， 弹 出 如 图 1.47 所 示 的 “应 用 程序 配置 ”对 话 框 。 


目录 人性 | jmrP 半 | 自 定 X 桂 误 | IISAraemite | 
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图 1.47 应 用 程序 配置 

(5) 选择 “映射 ”选项 卡 ， 完 成 添加 、 编 辑 应 用 程序 扩展 。 单 击 “ 添 加 ”按钮 ， 在 弹出 的 如 图 1.48 所 示 
对 话 框 中 首先 指定 可 执行 文件 ， 这 里 指定 的 是 存储 在 系统 盘 的 system32\inetsrv\ 文 件 夹 下 的 fcgiext.dll 文件 ， 然 
后 设置 扩展 名 为 “.php”， 最 后 单 击 “ 确 定 ”按钮 ， 返 回 到 “默认 网 站 属性 ”对 话 框 。 

(6) 选择 “文档 ”选项 卡 ， 添 加 一 个 .php 的 默认 页 。 添 加 后 的 效果 如 图 1.49 所 示 。 


图 1.46 “ 主 目录 ”选项 卡 
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图 1.49 添加 默认 页 


1.48 添加 PHP 扩展 
(7) 关闭 所 有 对 话 框 ， 重 启 IS 服务 器 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 中 单 击 “ 添 加 /删除 程序 ”按钮 。 


(2) 单 击 左 侧 的 “添加 /删除 Windows 组 件 ” 按 钮 ， 弹 出 “Windows 组 件 向 导 ” 对 话 框 。 依 次 选中 并 双击 
“Windows 组 件 向 导 ” 对 话 框 中 的 “应 用 程序 服务 器 ”选项 、“ 应 用 程序 服务 器 ”窗口 中 的 “Internet 信息 服务 


22 


第 1 章 开发 环境 
(IIS) ”选项 、“Intemet 信息 服务 (IS) ”对 话 框 中 的 “万 维 网 服务 ”选项 。 最 后 选中 “万 维 网 服务 ” 复 选 框 。 
(3) 设置 完毕 后 单 击 “ 确 定 ” 按 钮 。 具 体操 作 过 程 如 图 1.50 所 示 。 
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1.50 Intemet 信息 服务 (IIS) 
安装 完成 后 即 可 使 用 IS。 
秘笈 心 法 


心 法 领悟 010， 测试 IIS 是 否 安装 成 功 。 

安装 IS 后 ， 即 可 在 正 浏览 器 的 地 址 栏 中 输入 http://localhost， 测 试 HS 是 否 安装 成 功 。 

如 果 本 机 的 80 端口 被 Apache 占用 ， 那 么 就 需要 修改 IS 的 端口 号 。 例 如 修改 为 82 端口 ， 那 么 测试 时 应 该 
在 地 址 栏 中 输入 http://localhost:82/。 


一 一 
图 实例 说 明 


本 实例 编写 第 3 个 PHP 脚本 ， 在 IS 服务 器 下 运行 ， 测 试 通过 IS+PHP+MySQL 搭建 的 PHP 开发 环境 是 否 
成 功 ， 运 行 结果 如 图 1.51 所 示 。 


本 文 作品 ”后 作 Q 查看 W) 窗口 W) 得 吕 | = 村 
人 地 | 白 回 | 多 日 | 国 轩 | 忌 | ， 1 
图 et 全 请 服务 
Ee 

RY 
Ds 


IIStPHPHIYSQL 独 立 棋 建 PEP 开 发 环境 测试! 


I l 
1.51 测试 独立 环境 是 否 措 建 成 功 


图 关键 技术 


确定 IS 服务 器 设置 的 本 地 路 径 , 这 是 在 IS 的 配置 中 完成 的 ， 必 须 将 PHP 脚本 存储 于 IIS 设置 的 本 地 路 径 
下 才能 够 运行 。 


PHP 开发 实例 大 全 (基础 卷 ) 


图 设计 过 程 
(1) 在 IIS 指定 的 本 地 路 径 下 〈F:\PkhiisPHP\www) 新 建 一 个 文本 文档 ， 在 该 文档 中 输入 如 下 内 容 : 
Ce 独立 搭建 PHP 开发 环境 测试 !"; 


(2) 将 该 文档 重 命名 为 index.php。 

(3) 选择 “开始 ”/“ 设 置 ”"/“ 控 制 面板 ”命令 , 在 弹出 的 窗口 中 双击 “管理 工具 ”图 标 , 然后 选择 “Internet 
信息 服务 〈IS) 管理 器 ”选项 ， 依 次 展开 “本 地 计算 机 ”和 “网 站 ”节点 ， 右 击 “ 默 认 网 站 ”选项 ， 在 弹出 的 
快捷 菜单 中 选择 “浏览 ”命令 ， 若 在 “Intemnet 信息 服务 〈IS) 管理 器 ”窗口 的 右 侧 输出 如 图 1.51 所 示 的 内 容 ， 
说 明 独 立 环境 搭建 成 功 。 


秘笈 心 ; 


心 法 领悟 011: IS 中 的 UrlRewrite 技术 。 

UrlRewrite 即 地 址 变换 ， 可 以 实现 静态 功能 ， 方 便 搜 索引 擎 收录 ， 比 如 http://***/news.php?id=1 可 以 变 为 
htt://***/news-1.html。 不 但 可 以 实现 开发 标记 的 隐藏 ,而 且 避 免 每 个 页 面 都 输出 .php 后 级 ， 进 而 提高 网 站 的 安 
全 性 。 

IIS 默认 是 不 支持 此 功能 的 ， 需 要 单独 安装 插件 ISAPI_Rewrite3_0048_Lite.msi。 安 装 完成 后 打开 IS， 在 
Web 属性 的 “ISAPI 筛选 器 ”里 添加 位 于 安装 目录 的 HeliconSAPI Rewrite3 文件 夹 里 的 ISAPI Rewrite.dll 即 可 ， 
名 称 可 以 自 定义 。 


1.4 LAMP 一 一 独立 配置 PHP 开发 环境 


在 Linux 下 搭建 PHP 环境 比 在 Windows 中 要 复杂 一 些 ， 除 了 Apache、PHP 等 软件 外 ， 还 要 安装 一 些 相关 
工具 ， 并 设置 必要 参数 。 这 里 给 出 在 Linux 下 搭建 PHP 环境 的 必要 步骤 ， 如 果 用 户 在 安装 过 程 中 遇 到 特殊 的 问 
题 ， 还 需要 翻阅 与 Linux 相关 的 资料 、 书 籍 或 者 手册 。 

安装 之 前 要 准备 的 安装 包 如 下 : 

回 apache 1.3.41.tar.gz 

回 php-5.0.0.tar.gz 

Inysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz 

libxml2-2.6.19.tar.gz 


[ED 说 明 : 本 书 中 在 讲解 Linux 下 搭建 PHP 开发 环境 时 ， 使 用 的 软件 版 本 相对 较 低 ， 如 果 读 者 想 要 下 载 这 些 软 
件 ， 可 以 登录 http://221.8.65.77/mrbook/bookzy/linux.rar。 
这 里 首先 在 Linux 系统 的 /usr/local/ 文 件 夹 下 新 建 一 个 work 文件 夹 ,并 将 使 用 的 软件 全 部 存储 在 此 文件 夹 下 。 


| 


实例 012 趣味 指数 : obodolod 


力 实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 Apache 服务 器 。Apache 服务 器 安装 成 功 后 测试 的 运行 结果 如 图 1.52 
所 示 。 
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总 四 LJ 
| 文 作 四。 坊 忽 EE) 查看 CD 特 球 G@) 书 容 B 工 尼 D 窗口 Ww》 有 有 助 四 || 


到 ” 候 旧 ”重新 增 入 打印 
| 盟主 页 遗书 答 参 Red Hat Network 泗 Sppont 前 Shop 舞 Products 区 Training 


| 
| 息 - 况 - 时 ”可 [ipanov [vB 吕 > 
| 


| 
| 

Apache 的 文件 已 经 包含 在 该 版 本 中 。 
你 可 以 在 使 用 Apache 的 网 站 伺服 器 上 ， 自 由 的 使 用 下 面 之 图 示 ， 感 潮 你 | 
使 用 Apache ! | 
| 


“i ACE 


泥 囊 风 国 | 基态 [i 


图 1.52 Apache 配置 成 功 


图 关键 技术 


Linux 系统 下 配置 Apache 服务 器 使 用 的 仍 是 httpd.conf 文件 ， 该 文件 位 于 /usr/local/apache/conf 中 。 
(1) 在 httpd.conf 文件 中 ， 定 位 到 如 图 1.53 所 示 的 位 置 ， 添 加 相应 的 内 容 ， 并 设置 PHP 文件 的 后 组 。 
(2) 同样 在 httpd.conf 文件 中 ， 定 位 到 如 图 1.54 所 示 的 位 置 ， 设 置 PHP 文件 的 默认 页 。 


soarehe/eon ttnd en 
文 作坊 名 EE) 查看 (V) 搜索 3 工具 了 。 文档 (D) 有 有 助 t 
加 加 .加 | 久 /9 人 @ 旬 DDG, 
新 建 打开 保存 打印 撤消 乎 复 剪 切 复制 粘贴 查找 

站 wpdeonte x 


文 八 ED 蛇 镍 (EE) 。 查看 (V) 搜索 (工具 ID。 文档 ID 帮助 (H) 


苹 鲁 .加 | 钙 le 区 虽 白 | 己 ， 


新 建 打开 。 保存 打印 撤消 平复 ”前 切 复制 籼 同 ”查找 


apdeont x 


目标 定位 
AdiType_ application/x-gzip .gz .gz 
ATYpe_application/x-hupd- php_ ,php MMME) .php4 
大 | 


添加 内 容 
# AddHandlar_ allows_vou tn_man_certain 有 
行 774, 列 43 插入 


1.53 ”设置 文件 后 缀 图 1.54 设置 默认 文件 
图 设计 过 程 
安装 Apache 服 务 器 ,首先 需要 打开 Linux 终端 (Linux 下 几乎 所 有 的 软件 都 需要 在 终端 下 安装 )。 选 择 RedHat9 
的 “ 主 菜单 ”/“ 系 统 工具 ”命令 ， 在 弹出 的 子 菜单 中 选择 “终端 ”命令 。Apache 服务 器 的 安装 步骤 如 下 : 
(1) 解压 apache_1.3.41.tar.gz 压缩 包 ， 将 其 存储 到 /urllocal/apache 目录 下 ， 执 行 的 命令 如 图 1.55 所 示 。 


NM east/ vor 34 x 
ET | 


《lfModule mod_dir.c> 
DirectoryIndex index.html [index.phg] 
IIModule> 


扩 
AdjType application/x-compress 了 


行 364, 列 40 


Wr 1 
installation path layout: Apache (config. layout) 
ia Miefile 

[Greating Configuration.apaci in sre 

[Greating Mkefile in sre/support 

[Greating Mkefile in sre/regex 


‘2 Mkefil Juni 


eR 代码 导读 
@ 进入 Apache 安装 文件 的 目录 。 
@ 解压 Apache 服务 器 的 安装 包 。 
目 进入 apache 1.3.41 目录 。 
@ 将 Apache 服务 器 安装 到 /usr/local/apache 目录 下 。 


PHP 开发 实例 大 全 (基础 卷 ) 


(2) 执行 make 命令 ， 编 译 apache 文件 。 执 行 命令 如 图 1.56 所 示 。 
(3) 执行 make install 命令 ， 开 始 安 装 Apache 服务 器 。 执 行 命令 如 图 1.57 所 示 。 
BA sooo/s/ba ot 3 


文件 ED 编辑 人 E) ”查看 (V) ”终端 D 。 转 到 KG) 帮助 四 
+ checking for system header files 

+ adding selected mdules 

+ using system Expat 

+ using -1d1 for vendor DSO suppor! 

+ checking sizeof various data types 

+ doing sanity check on conpiler and options 

ng Mkefile in sre/sepport 

ng Mkefile in sre/regex 


文件 四。 编辑 (E) ”查看 (V) ”终端 D ” 转 到 (G) ”帮助 由 
mkel1]: Leaving directory /usr/local/wrk/apache_1.3.41" 


mke[2]: Entering directory “/usr/local/work/apache_1.3.41/sre’ ===> [nktree: Crea ting Apache installation tree] 
=- sre/regex Lsre/e tpers/mkdir .sh /usr/ localapache/bin 


图 1.56 执行 make 命令 编译 文件 图 1.57 执行 make install 安装 命令 
(4) Apache 服务 器 安装 成 功 后 ， 将 给 出 如 图 1.58 所 示 的 命令 提示 。 


~ PT TT EE 人 X 
文件 已 坊 辑 (E) ”查看 (VI 。 终端 了。 特 到 @) 帮助 QD 
make[1]:; Leaving directory /usr/local/work/apache_l 


| You now have successfully built and installed the 
| Apache 1.3 HTTP server- To verify that Apache actually 
| works correctly you now should first check the 

| Cinitially ereated or preserved) configuration files 


1 
1 /usr/local/apache/conf/httpd.conf 
1 

| and then you should be able to immediately fire up 
| Apache the first Line by running: 


1 
| oust/local/apache/bin/apachectl start 
1 
| Thanks for using Apache The Apache Group 

1 hitp:// ww.apache .org/ 


图 1.58 ”安装 成 功 返回 命令 


图 秘笈 心 法 


心 法 领悟 012，Linux 下 启动 Apache。 

安装 成 功 后 ， 就 可 以 启动 Apache 服务 器 了 ， 启 动 Apache 服务 器 使 用 的 命令 如 图 1.59 所 示 。 
~ Er 
| 文人 (BD 编 名 EE) 查看 (Ww 奖 洋 DD 转 玛 @)。 邦 WD | 
[root@loca lhost apache_1.3.41]# /usr/local/apache/bin/apachect! start 


usr/ local/apache/bin/apachectl start: httpd started 
root rec thost apsche 1.3.41]s 


图 1.59 执行 启动 Apache 服务 器 的 命令 


实例 013 


力 实例 说 明 


osteo pt/ 2 


本 实例 讲解 在 Linux 下 安装 MySQL 数据 库 , 使 用 的 版 本 是 mysql-standard-5.0.0- alpha- pc- linux-i686 .tar.gz。 


力 关键 技术 
(1) 在 Linux 操作 系统 中 ， 备 份 和 还 原 MySQL 使 用 的 命令 如 下 : 


第 1 章 开发 环境 
备份 : 


mysqldump -uroot -proot -R 数据 库 名 称 >C:/data.sql 
还 原 : 
mysql -uroot -proot-D 数据 库 名 称 < C:/data.sql 
(2) 在 Linux 操作 系统 中 ， 设 置 和 修改 root 用 户 密码 的 命令 如 下 : 
设置 密码 ;: 
mysqladmin —uroot password root 
修改 密码 : 
mysqladmin -uroot -p 旧 密 码 password 新 密码 
图 设计 过 程 
下 面 讲解 其 具体 的 安装 步骤 。 
(1) 安装 MySQL 数据 库 同样 要 在 Linux 终端 的 命令 中 进行 。 首 先 创建 MySQL 账号 ， 并 将 新 建 账号 加 入 
到 组 群 ， 具 体 使 用 的 操作 命令 如 图 1.60 所 示 。 


ou have to copy support-riles/mysql.serve' 
system 


th tbe benchomrks in the 


a sat-bench’ sisectory: | 
图 1.60 MySQL 的 安装 命令 


eR 代码 导读 

创建 MySQL 账号 。 

加 入 组 群 。 

进入 MySQL 安装 文件 的 目录 。 

解压 MySQL 服务 器 软件 。 

以 链接 的 方式 建立 /usrllocalmysql 目录 。 

进入 MySQL 目录 。 

在 /usr/local/mysql/data 中 建立 MySQL 数据 库 。 


(2) 在 完成 数据 库 的 安装 之 后 ， 修 改 文件 的 权限 。 具 体操 作 命令 如 图 1.61 所 示 。 


oooceooeoeoe 


sql-bench’ dir 
ript! 
sbout MSQL is available on the web at 


thttps://order .rysql .com 


1 
[root@loca lhost mysqll# lchgrp -R msql . 


图 1.61 修改 文件 权限 的 命令 
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(3) 完成 权限 修改 后 ， 看 一 下 启动 MySQL 服务 器 的 命令 。 具 体 命 令 如 图 1.62 所 示 。 


文 作 E) 编辑 E) 查看 终 奖 了。 转 于 G) 帮助 细 
| oca Ihost nysql]#[/usr7Ioca I7rysql/bin/nysqlds 
1 


1.62 启动 MySQL 的 命令 


国 秘 稚 心 法 


心 法 领悟 013: Linux 下 修改 MySQL 数据 库 用 户 的 密码 。 
可 以 通过 命令 修改 MySQL 数据 库 用 户 的 密码 .在 如 图 1.63 所 示 的 命令 中 ,首先 以 无 密码 的 方式 登录 MySQL 
数据 库 ， 然 后 通过 命令 设置 MySQL 数据 库 用 户 的 密码 ， 最 后 通过 新 设置 的 密码 重新 登录 MySQL 数据 库 。 


“~ Er x 
| 文件 E) 编辑 EE) ”查看 (V) 疼 油 DD 转 至 G) 有 盈 ) | 
Jroot@loca lhost nysql]# [usr7Tocn T7177 00 | | 
(Wleone to the MSQL nonTior. Commn ror wg. | | 
Your MSOQL connection id is 1 to serve 5.0.0-aIpha— STandard— 


Type “help:’ or '\h"’ for help. Type '\e' to clear the buffer. 


[yet wa ER 

[Bye i 

[root@loca lhost nysql]# E 
[root@loca Ihost nysql]# [usr7Toca Tny sq TP In7 nyaT “uroor “Prod!] 
Wlcone to the MSQL nmonitor. Conmnds end wi 


说 MSQL connection id is 4 to server versii 


| "help;i' or '\h’ for help. Type '\e’ to char the buffer. 
| we | 
图 1.63 登录 MySQL 和 设置 MySQL 登录 密码 


中 级 
趣味 指数 : 富 坪 商 穴 


实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 PHP 5.0。 安 装 之 前 , 首先 需要 查看 libxml 的 版 本 号 , 如 果 小 于 2.5.10， 
则 需要 先 安装 libxml 的 高 版 本 ， 否 则 ， 可 以 直接 安装 PHP 5.0。 


力 关键 技术 


这 里 以 libxml2-2.6.19.tar.gz 为 例 ， 讲 解 libxml 的 安装 步骤 。 
(1) 将 libxml2-2.6.19.tar.gz 进行 解压 ， 并 将 其 安装 到 指定 的 文件 夹 下 ， 其 操作 命令 如 图 1.64 所 示 。 


~ rr rr 二 x 
| 文 (KB 编辑 (E) ”查看 (VW 终端 D 转 


图 1.64 解压 libxml 


ES 
ER 代码 导读 
@ 进入 /usrlocal/work 文件 夹 〈libxml2-2.6.19 压缩 包 存 储 的 位 置 ) 。 


@e 
- 
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四 解压 libxml2-2.6.19.tar.gz。 
目 进入 libxml2-2.6.19 文件 夹 。 
@ 将 libxml2-2.6.19 安装 到 /usrlocallibxml2。 


(2) 完成 libxml 的 解压 后 ， 开 始 编译 文件 ， 使 用 的 命令 如 图 1.65 所 示 。 
(3) 文件 编译 完成 后 ， 就 可 以 执行 安装 操作 了 ， 使 用 的 命令 如 图 1.66 所 示 。 


| 回 LjL 
转 到 @) 


帮助 


图 1.65 编译 文件 


图 设计 过 程 
本 书 使 用 的 版 本 是 php-5.0.0.tar.gz。 下 面 来 看 具体 的 安装 步骤 。 
(1) 将 php-5.0.0.tar.gz 解压 到 指定 的 文件 夹 下 ， 通 过 命令 进行 配置 ， 使 用 的 操作 命令 如 图 1.67 所 示 。 


[EX 
终端 转 到 G) 帮助 


Y 
文件 BD。 坊 辑 E) 查看 (办 
[ 


Toea 
AT NE-S OO Tar ET 
TTT]e 
——with-apxs=/usr/local/apache/bin/apxs \ 
ibxml-dir=/usr/ local/ libxml2 一 enable-sock| 


1.67 安装 PHP 


ok 
eS 代码 导读 
@ 进入 /usrlocal/work 文件 天 《php-5.0.0.tar.gz 压缩 包 存 储 的 位 置 ) 。 
@ 解压 php-5.0.0.tar.gz。 
目 配置 文件 。 


(2) 完成 解压 和 配置 操作 后 ， 对 文件 进行 编译 ， 使 用 的 命令 如 下 : 

make 

(3) 编译 完成 后 ， 执 行 安装 操作 ， 使 用 的 命令 如 下 : 

make install 

(4) 最 后 ， 在 命令 中 将 出 现 如 图 1.68 所 示 的 内 容 ， 说 明 PHP 安装 成 功 。 


~ PTET TT 一 呈 
件 (EE 坊 辑 (ED 查看 (由 兰 痪 D。 转 到 G) 新山 


ost php-5.0.018 上 


> = 
图 1.68 PHP 安装 成 功 
国 秘笈 心 法 


心 法 领悟 014: 在 Linux 下 创建 php.ini。 
在 Linux 操作 系统 中 ，PHP 的 配置 文件 仍然 是 php.ini， 其 创建 方法 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


在 PHP 文件 夹 下 找到 php.ini-dist 或 者 php.ini-recommended， 将 其 复制 到 /usr/local/lib 目录 下 ， 并 重 命名 为 


php.ini。 
cp php.ini-dist /usr/local/lib/php.ini 


中 级 
起 呆 撒 娄 ， 宙 六 个 


实例 015 


力 实例 说 明 


在 Linux 系统 下 搭建 完成 PHP 开发 环境 后 ， 编 写 一 个 小 实例 ， 测 试 环境 是 否 拱 建成 功 。 在 Mozilla 浏览 器 
的 地 址 栏 中 输入 http://localhost/test.php， 运 行 结果 如 图 1.69 所 示 。 
Er _ 书 答 四 ITROD 座 DQD 帮助 四 二 | 


访 Sn MB 或 - 


前 进 匣 新 载 入 正 


盘 计 页 | 寻 书 签 大 Red Hat Newak 散 Sappon 散 Sshm 区 Prodocts 前 Te 


im localhost Jocakdomain 24.20-8 #1 Thu Mar 13 17:54:28 EST 2003 686 
[Build Date [May 5 2006 104308 


' 


L 
| 
| 


1.69 测试 运行 结果 


图 关键 技术 

在 Linux 操作 系统 下 ， 通 过 gedit 工具 编写 PHP 脚本 。 
图 设计 过 程 

通过 gedit 工具 编写 一 个 PHP 脚本 testphp， 并 存储 于 Apache 的 htdocs 文件 夹 下 。testphp 的 代码 如 图 1.70 
所 示 。 


| 加 Ej 
文 作 (E) 坊 辑 EE) ”查看 (VW) 。 搜索 (3) 工具 D 文档 D) 帮助 由 


久久 . 回 | 号 | 多 人 贡 罩 自 区 ， 


新 建 打开 。 保存 打印 的 消 再 复 ”前 切 复制 粘贴 ”查找 
FD estphp x 
[php 
phpinfo0: 
2> 
行 2, 列 5 插入 


图 1.70 testphp 文件 的 内 容 
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心 法 领悟 015: Linux 下 安装 XAMPP 集成 环境 。 
本 实例 介绍 的 是 在 Linux 操作 系统 下 独立 搭建 PHP 的 开发 环境 ， 读 者 也 可 以 使 用 XAMPP 的 
xampp-linux-1.7.3a.tar.gz 版 本 直接 在 Linux 操作 系统 下 搭建 集成 的 开发 环境 。 


1.5 XAMPP 一 一 Linux 版 PHP 集成 化 安装 包 


前 面 已 经 介绍 过 如 何在 Windows 操作 系统 下 应 用 XAMPP 集成 化 安装 包 配 置 PHP 的 开发 环境 ， 这 里 将 介 
绍 如 何在 Linux 操作 系统 下 通过 XAMPP 配置 PHP 的 开发 环境 以 及 其 基本 应 用 。 


趣味 指数 : 食 食 诬 谷 


力 实例 说 明 
在 Linux 操作 系统 下 ， 也 可 以 使 用 集成 的 软件 来 配置 PHP 开发 环境 ， 它 就 是 XAMPP 的 Linux 版 。 配 置 成 


功 后 ， 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/index.php， 运 行 结果 如 图 1.71 所 示 。 
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文 作 (E) 编辑 (E) 查看 (WD 转 到 @) 书签 BB) 工具 也 请 口 (WD 帮助 由 
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1.71 Linux 版 的 XAMPP 


国 关键 技术 


在 Linux 操作 系统 下 安装 XAMPP， 必 须 在 Linux “ 主 菜单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 通过 指令 
来 完成 ， 切 记 不 要 使 用 任何 微软 操作 系统 下 的 工具 来 进行 操作 。 


图 设计 过 程 


Linux 下 安装 XAMPP 的 步骤 如 下 : 


q 


PHP 开发 实例 大 全 (基础 卷 ) 


(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命令 。 

(2) 在 命令 模式 下 ， 首 先进 入 系统 的 根 目录 。 

(3) 通过 mkdir 命令 在 根 目 录 下 创建 一 个 opt 目录 。 

(4) 通过 tar xvfz 命令 将 xampp 解压 缩 到 opt 目录 下 。 

(5) 按 Enter 键 ， 执 行 XAMPP 的 解压 缩 ， 直 到 安装 成 功 ， 其 具体 使 用 的 命令 如 图 1.72 所 示 。 
(6) 安装 成 功 后 ， 查 看 /optlampp 目录 ， 如 图 1.73 所 示 。 


文件 E) 编辑 EE) ”查看 (WD 。 转 到 (G) ”书签 B) ”帮助 由 


qq -aa @% A 
后 退 ”前进 ”向 上 一 级 停止 刷新 ， 主 文件 燃 图 
位 置 。 [ET | -B+ | View as los > 

r lhos bmn 

[root@localhost /]# tar xvfz xanpp-linux-1.5.3a.tar.gz -C /op!| 号 < 
选中 了 “bmpp” (有 20 项 ) 

图 1.72 XAMPP 的 安装 图 1.73 查看 安装 的 内 容 
光 
秘笈 心 法 


心 法 领悟 016: Linux 下 安装 XAMPP 的 注意 事项 。 
在 Linux 操作 系统 下 执行 XAMPP 的 解压 缩 时 ， 必 须 进入 系统 的 根 目录 下 ， 并 在 根 目录 下 创建 一 个 子 目 录 ， 
然后 才 可 以 执行 解压 缩 的 命令 ， 否 则 将 提示 找 不 到 指定 的 目录 或 者 文件 。 


. 
动 XAMPP 中 级 | 


力 实例 说 明 


在 实例 016 中 , 已 经 介绍 了 如 何在 Linux 操作 系统 下 安装 XAMPP， 本 实例 我 们 将 介绍 在 Linux 操作 系统 下 
如 何 启 动 XAMPP， 其 使 用 的 命令 如 图 1.74 所 示 。 


~ 
文件 (E) 编辑 EE) 查看 (WD 终端 D 和 转 至 @) 帮助 内 
/opt/ lanpp/ lanpp start 

Linux 1.5.3a.. 


Star ting XANPP 
XAMPP: h SSL (and PHPS)... 


1.74 ”启动 XAMPP 


力 关键 技术 
在 Linux 操作 系统 下 启动 XAMPP， 同 样 要 进入 Linux “ 主 菜 单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 ， 所 


使 用 的 命令 如 下 : 
/opt lampp/lampp start 


图 设计 过 程 
Linux 下 启动 XAMPP 的 步骤 如 下 : 


第 1 章 开发 环境 


(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命 令 。 

(2) 直接 输入 命令 /opt/lampp/lampp start。 

(3) 按 Enter 键 ， 执 行 XAMPP 的 启动 操作 。 命 令 运行 结果 如 图 1.75 所 示 。 
ee 


图 1.75 XAMPP 启动 成 功 


图 秘笈 心 法 
心 法 领悟 017: 停止 XAMPP 的 命令 。 


Linux 下 停止 XAMPP 的 命令 如 下 : 
/opt/lampp/lampp stop 


到 


力 实例 说 明 


在 XAMPP 中 ， 默 认 情况 下 通过 phpMyAdmin 以 root 用 户 的 身份 登录 MySQL 数据 库 是 不 需要 密码 的 ， 
为 了 确保 数据 库 的 安全 ， 应 该 给 root 用 户 设置 一 个 密码 。 这 就 是 本 实例 要 介绍 的 内 容 一 一 如 何 为 root 用 户 设置 
密码 。 


图 关键 技术 


在 Linux 操作 系统 下 为 MySQL 数据 库 的 root 用 户 设置 密码 使 用 的 命令 如 下 : 
rn 
图 设计 过 程 
Linux 下 设置 MySQL 数据 库 root 用 户 密码 的 步骤 如 下 : 
(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命 令 。 
(2) 直接 输入 命令 /opt/lampp/bin/mysqladmin -u root password "111"， 这 里 设置 root 用 户 的 密码 为 “111”。 
(3) 按 Enter 键 ， 执 行 该 命令 ， 其 运行 结果 如 图 1.76 所 示 。 


图 1.76 设置 root 用 户 的 密码 


国 秘笈 心 ; 
心 法 领悟 018: 卸载 XAMPP 命令 。 
Linux 下 印 载 XAMPP 的 命令 如 下 : 


mm -rf /optlampp 


PHP 开发 实例 大 全 (基础 卷 ) 


趣味 指教: 三 页 让 从 } 


目 


力 实例 说 明 


Linux 系统 下 PHP 的 集成 开发 环境 XAMPP 已 经 配置 成 功 ， 下 面 编写 一 个 小 实例 ， 应 用 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 通 过 这 个 实例 熟悉 一 下 在 Linux 下 XAMPP 的 运用 。 在 Mozilla 浏览 器 的 地 址 栏 中 输入 
http://127.0.0.1/text/index.php， 运 行 结果 如 图 1.77 所 示 。 
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图 1.77 输出 PHP 的 配置 信息 


图 关键 技术 


在 Linux 操作 系统 下 运用 XAMPP 开发 PHP 程序 ， 首 先 要 确立 XAMPP 的 程序 运行 文件 夹 ， 即 明确 创建 的 
程序 要 存储 在 哪个 文件 夹 中 才 可 以 运行 。XAMPP 中 的 重要 档案 和 目录 如 下 : 
/opt/lampp/bin/: XAMPP 指令 的 根 目录 。 例 如 ，/opt/lampp/bin/mysql 用 来 执行 MySQL。 
/opt/lampp/htdocs/: Apache 文件 根 目录 。 
/opt/lampp/etc/httpd.conf: Apache 设 定 档案 。 
/optlampp/etc/my.cnf: MySQL 设 定 档案 。 
/opt/lampp/etc/php.ini: PHP 设 定 档案 。 
/opt/lampp/phpmyadmin/config.inc.php: phpMyAdmin 设 定 档案 。 
看 设计 过 程 

在 XAMPP 中 开发 PHP 程序 的 操作 步骤 如 下 : 

(1) 首先 通过 gedit 工具 编写 一 个 PHP 脚本 ， 应 用 phpinfo0 函 数 输 出 PHP 的 配置 信息 ， 如 图 1.78 所 示 。 


(2) 选择 图 1.78 中 的 “文件 ”/“ 另 存 为 ”命令 ， 将 该 文件 存储 于 XAMPP 的 htdocs/ 目 录 下 ， 并 且 命名 为 
index.php， 如 图 1.79 所 示 。 


加 回回 回回 加 


新 建文 件 夹 (N) | 蓟 除 文件 DD | 重 命名 文件 BR 


/opVlampp/htdocs ~ 


文件 夹 (D) | 文人 (Dp 
| index.html | 


~v 转 1 gedit 
文件 四 ”编辑 E) ”查看 (WW 搜索 8) 工具 WD 文档 D) 帮助 由 
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(BD.QS ee, 


新 建 打开 保存 打印 撤消 至 各” 剪 切 复制 粘贴 ”查找 


口 来 三 各 于 % 选中 (8): /opVlampp/htdors 
php - B 

echo phpinfoo [index pi 

?> 


行 2, 列 16 插入 
图 1.78 编辑 PHP 脚本 文件 图 1.79 完成 PHP 文件 的 存储 
(3) 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/text/index.php， 运 行 结果 如 图 1.77 所 示 。 
秘笈 心 法 


心 法 领悟 019: Linux 下 修改 MySQL 默认 字符 集 。 
在 Linux 下 修改 MySQL 默认 字符 集 为 utfg， 操 作 的 文件 是 my.cnf， 操 作 的 内 容 如 下 : 


[client] 
default_character_set=utf8 


[mysqld] 

# default-character-set=utf8 
character-set-server = utf8 
collation-server = utf8_general_ci 
[mysql] 
default_character_set=utf8 


1.6 Dreamweaver 开发 工具 


Dreamweaver 是 Macromedia 公司 开发 的 Web 站 点 和 应 用 程序 的 专业 开发 工具 ， 它 将 可 视 布 局 工具 、 应 用 
程序 开发 功能 和 代码 编辑 组 合 在 一 起 。 


实例 020 趣味 指数 : 请 请 雪 家 
实例 说 明 


应 用 Dreamweaver 开发 网 站 ,首先 必须 考虑 网 页 的 编码 格式 的 选择 。 如 果 网 页 的 编码 格式 有 局 限 性 ， 
那么 将 导致 网 站 在 一 些 特定 的 情况 下 运行 时 出 现 乱 码 ， 将 不 利于 网 站 程序 的 后 期 更 新 和 维护 。 例 如 ， 如 
果 网 站 在 编写 时 使 用 的 是 GB2312 编码 ， 当 程序 在 繁体 操作 系统 中 运行 时 就 会 出 现 乱码 ， 结 果 如 图 1.80 
所 示 。 
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1.80 ”繁体 操作 系统 下 查看 GB2312 编码 格式 文件 与 源 文件 对 比 


图 关键 技术 


对 于 网 站 的 开发 ， 编 码 格式 的 选择 很 重要 。 如 果 使 用 Dreamweaver 开发 网 站 ， 那 么 可 以 选择 “编辑 ”/“ 首 
选 参 数 ”/“ 新 建文 档 ”/“ 默 认 编码 ”命令 设置 新 建文 件 的 编码 格式 。 这 样 就 不 必 再 为 创建 的 每 个 文件 的 编码 而 
担心 ， 因 为 它们 的 编码 格式 是 统一 的 。 
图 设计 过 程 


统一 Dreamweaver 创建 文件 编码 格式 的 方法 如 下 : 
(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 编 辑 ”/“ 首 选 参 数 ”命令 ， 弹 出 如 图 1.81 所 示 对 话 框 。 


和 RR 
Warsw me 
Rs [Tt 
Ia Om) [mi roi 可 


htcods 4 二 $ | 了 可 
三 全 wind 宇和 am G) 
太 报 contrat 刀 人 久生 示 “于 广 村 对 放权 人 0 


1 | | 


1.81 设置 文件 的 编码 格式 
(2) 在 其 中 指定 默认 编码 ， 最 后 单 击 “确定 ”按钮 。 


图 秘笈 心 法 


心 法 领悟 020: 在 Dreamweaver 中 设置 编码 。 

在 Dreamweaver 的 “首选 参数 ”设置 中 ， 不 但 可 以 设置 默认 编码 的 格式 ， 还 可 以 进行 其 他 设置 ， 如 CSS 样 
式 、 站 点 和 字体 等 。 

对 于 文件 编码 格式 的 选择 ， 强 烈 建议 读者 使 用 UTF-8， 因 为 这 样 可 以 与 国际 接轨 ， 如 果 单纯 地 使 用 GB2312 
编码 ， 那 么 一 旦 程序 要 更 改编 码 格式 ， 网 页 将 出 现 乱 码 。 如 果 使 用 UTF-8 编码 格式 ， 就 不 会 出 现任 何 问题 ， 因 
为 这 个 编码 格式 是 通用 的 。 

ee 
oh 中 级 .| 
实例 021 | 2 


四 实例 说 明 


实例 020 讲解 了 如 何在 Dreamweaver 中 设置 编码 格式 ， 下 面 介绍 一 下 Dreamweaver 的 具体 应 用 一 一 在 
Dreamweaver 中 创建 表格 。 运 行 结果 如 图 1.82 所 示 。 
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1.82 在 Dreamweaver 中 创建 表格 


图 关键 技术 


在 Dreamweaver 中 创建 表格 ， 有 两 种 方法 : 

第 一 种 ， 选 择 菜 单 栏 中 的 “插入 ”/“ 表 格 ”命令 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 操作 。 

第 二 种 ， 直 接 在 “常用 ”工具 栏 中 单 击 “ 表 格 ” 按 钮 国 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 操作 。 
图 设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 如 下 : 


(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 文 件 ”/“ 新 建 ” 命 令 ， 在 弹出 的 “新 建文 档 ” 对 话 框 中 创建 一 
个 “动态 页 ”/PHP 文件 ， 最 后 单 击 “ 创 建 ” 按 钮 ， 完 成 动态 PHP 文件 的 创建 ， 如 图 1.83 所 示 。 


图 1.83 创建 PHP 动态 文件 
(2) 如 图 1.84 所 示 ， 在 创建 的 Untitled-1 文件 中 ， 首 先 切换 到 设计 模式 下 ， 然 后 在 工具 栏 中 选择 “常用 ” 


| | an a | 


图 1.84 在 设计 模式 下 添加 表格 
(3) “表格 ”对 话 框 如 图 1.85 所 示 ， 在 其 中 可 以 设置 表格 的 行 数 、 列 数 、 表 格 宽度 、 边 框 粗细 、 单 元 格 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
边 距 和 单元 格 间距 等 。 设 置 完成 后 单 击 “ 确 定 ”按钮 ， 完 成 表格 的 创建 。 


图 1.85 “表格 ”对 话 框 
(4) 表格 创建 完成 后 ， 将 在 设计 界面 中 输出 如 图 1.86 所 示 的 内 容 。 
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1.86 创建 完成 的 表格 
(5) 选择 “文件 ” /“ 保 存 ” 命 令 ， 将 其 存储 于 Apache 服务 器 指定 的 文件 夹 下 ， 命 名 为 index.php。 运 行 结 
果 请 参考 实例 说 明 。 
图 秘笈 心 法 


心 法 领悟 021: 操作 表格 的 小 技巧 。 
在 图 1.86 所 示 的 表格 设计 界面 中 ， 表 格 处 于 选中 状态 时 ， 可 以 设置 其 属性 ， 包 括 行 数 、 列 数 、 表 格 宽度 、 
边框 粗细 、 单 元 格 边 距 、 单 元 格 间距 、 背 景 颜色 、 边 框 颜色 和 背景 图 像 等 。 


实 下 受 
实例 022 趣味 指数 : 让 丰 广 从 


图 实例 说 明 
实例 021 讲解 了 如 何在 Dreamweaver 中 创建 表格 ， 本 实例 将 讲解 如 何在 表格 中 插入 图 片 。 本 实例 的 运行 结 
果 如 图 1.87 所 示 。 


> 


1.87 表格 中 插入 宠物 图 片 


图 关键 技术 


在 Dreamweaver 中 ， 向 创建 的 表格 中 插入 图 片 时 ， 必 须 注意 图 片 的 存储 位 置 ， 最 好 的 方式 就 是 先 将 图 片 存 
储 到 实例 的 根 目录 下 ， 这 样 在 实例 运行 过 程 中 ， 不 会 因为 机 器 的 更 换 而 找 不 到 图 片 。 

如 果 没 有 将 图 片 存储 到 实例 的 根 目录 下 ， 在 执行 图 片 的 插入 操作 过 程 中 ， 将 给 出 一 个 如 图 1.88 所 示 的 提示 
信息 ， 提 示 是 否 将 图 片 存储 到 实例 的 根 目录 下 。 


图 1.88 插入 不 在 同一 驱动 器 上 的 文件 时 给 出 提示 


当 单 击 “ 是 ”按钮 时 ， 即 可 将 图 片 复制 到 实例 的 根 目 录 下 。 但 是 ， 这 种 做 法 有 一 个 弊端 ， 就 是 文件 的 存储 
没有 规范 性 。 试 想 一 下 ， 如 果 网 页 中 需要 插入 多 个 图 片 ， 程 序 的 根 目录 将 会 怎样 ? 所 以 最 好 的 方法 是 先 将 要 插 
入 的 图 片 存储 到 实例 根 目 录 下 的 一 个 指定 文件 夹 中 ， 这 样 做 比较 规范 ， 也 容易 管理 ， 一 般 都 将 这 个 图 片 存储 文 
件 夹 命名 为 images。 

如 果 在 图 1.88 的 提示 信息 中 ， 单 击 “ 否 ”按钮 虽然 图 片 仍然 可 以 插入 到 表格 中 ， 但 在 查看 网 页 代码 时 会 
发 现 ，img 标签 中 sre 属性 指定 的 图 片 文件 路 径 是 本 机 的 绝对 路 径 〈file:WEI/Program Files/9.gif) ， 在 本 机 中 仍 
然 可 以 运行 ， 但 要 将 本 实例 复制 到 其 他 机 器 上 运行 的 话 ， 在 指定 的 路 径 下 将 找 不 到 图 片 文 件 。 


图 设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 请 参考 实例 021， 这 里 不 再 歼 述 ， 下 面 介 绍 如 何在 创建 好 的 表格 中 
插入 图 片 。 

(1) 首先 ， 将 要 使 用 的 图 片 复制 到 本 实例 根 目 录 下 的 images 文件 夹 中 。 

(2) 将 光标 定位 到 要 插入 图 片 的 单元 格 中 ， 选 择 Dreamweaver 开发 工具 中 的 “插入 ”/“ 图 像 ”命令 ,在 
弹出 的 “选择 图 像 源 文件 ”对 话 框 中 选择 要 插入 的 图 片 ， 如 图 1.89 所 示 。 


EEC 
选取 文 上 名 全 三 文件 系统 
也 二 点 和 民生 


一 


EF 到 
Wm Bre | Wx 0 JIG /4 
0 ev IO 本 各 


也 


图 1.89 插入 图 片 
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(3) 确定 要 插入 的 图 片 之 后 ， 单 击 “确定 ”按钮 ， 即 完成 图 片 的 插入 操作 。 
(4) 保存 文件 ， 在 正 浏览 器 中 输入 网 址 ， 即 可 运行 本 实例 ， 运 行 结果 请 参看 实例 说 明 。 


图 秘笈 心 法 


心 法 领悟 022: 操作 Dreamweaver 小 技巧 。 
在 Dreamweaver 的 设计 模式 下 ， 当 选中 插入 的 图 片 时 ， 在 开发 工具 的 下 方 将 出 现 图 像 的 属性 操作 界面 ， 
如 图 1.90 所 示 。 通 过 这 个 属性 操作 界面 可 以 设置 图 像 的 宽度 、 高 度 、 链 接 以 及 是 否 添 加 地 图 等 。 


图 售 ，2r7 3 0 re S55 nl S| 8 
高 本 链 按 DD 加 本 到 OA 

[DJ BE | ”到 到 到 

R DIOM x*ruwl i) ER 本。 


图 1.90 图 像 的 属性 操作 界面 


起 味 指数 : 页 庚 页 窜 | 


实例 023 


力 实例 说 明 

本 实例 讲解 如 何在 Dreamweaver 中 创建 表单 。 表 单 是 网 站 与 客户 沟通 的 一 座 桥梁 ， 通 过 它 可 以 直接 将 客户 
的 信息 反馈 给 网 站 的 管理 者 ， 达 到 企业 与 网 站 浏览 者 更 好 的 交互 效果 。 在 本 实例 中 将 对 如 何在 Dreamweaver 中 
创建 表单 进行 详细 讲解 ， 实 例 的 运行 结果 如 图 1.91 所 示 。 


文件 中 铀 盖 G) 查看 0 收藏 人 ) 工具 T) 帮助 0 E32 
BED [mts io 0 0 tar/o1/ne3 PISE Rm 


[ 陋 二 入 不 硬 下 人 信和 ” 司 
简介 : 
到 


人 1 他: | 万 并 厂 全 三 文学 


图 书 过 库 : | PHP 开 发 实战 本 内 本 
ees | 
周 宁 | [| Bis 


图 1.91 创建 表单 元 素 


力 关键 技术 


在 Dreamweaver 中 创建 表单 ， 首 先 要 在 工具 栏 中 选择 “表单 ”选项 ， 然 后 就 可 以 通过 不 同 的 按钮 创建 不 同 
的 表单 元 素 ， 其 中 每 个 按钮 对 应 的 功能 如 表 1.1 所 示 。 
表 1.1 Dreamweaver 中 的 表单 元 素 
说 明 
<form name="form?2" method="post" action=""></form> 
name: 表单 的 名 称 


method: 表单 提交 的 方法 ， 包 括 POST 和 GET 方法 
action: 表单 提交 的 路 径 


像 


名 称 


文本 字段 
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<input type="text" name="textfield"> 
type: 应 用 表单 的 类 型 
name: 文本 框 的 名 称 


隐藏 域 


<input type="hidden" name="ID" value=""> 
type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 
name: 隐藏 域 的 名 称 ， 可 以 自己 定义 

Value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 


四 


文本 区 域 


复 选 框 


单 选 按钮 


单 选 按钮 组 


列表 \ 菜 单 


<textarea name="" cols="" IOWS="" id=""></textarea> 
<textarea>...</textarea>: 文本 域 的 标记 
name: 文本 域 的 名 称 ， 例 如 其 中 的 test 
cols: 表示 文本 域 字符 的 宽度 
rows: 表示 有 多 少 行 字符 
初始 值 在 <textarea></textarea> 标 记 之 间 进 行 输入 ， 例 如 其 中 的 “欢迎 大 家 访问 我 们 的 论坛 ” 
<input type="checkbox" name="checkbox" value=" 体 育 "> 
type: 表单 的 类 型 ， 其 中 的 checkbox 表示 复 选 框 
name: 复 选 框 的 名 称 ， 例 如 其 中 的 checkbox 
value: 复 选 框 提交 的 值 ， 例 如 其 中 的 “体育 ” 
checked: 如 果 希 望 预 先 为 用 户 选中 某 些 选项 ， 可 以 为 这 些 选项 加 上 checked 参数 
disabled: 如果 希望 某 一 个 选项 失效 ， 可 以 加 上 disabled 参数 
<input type="radio" name="radiobutton" value="radiobutton" checked="checked" /> 男 
<input type="radio" name="radiobutton" value="radiobutton" /> 女 
<input type="radio" name="RadioGroupl" value=" 单 选 " 放 单 选 
<input type="radio" name="RadioGroupl" value=" 单 选 " /> 单 选 
<select name="select2"> 
<option selected="selected"> 默 认 值 </option> 
<option value=" 对 应 值 1"> 列 表 值 1</option> 
<option value=" 对 应 值 2"> 列 表 值 2</option> 


</select> 
name: 指 该 <select> 组 件 的 名 称 
option: 提供 给 用 户 选择 的 项 目 ， 其 中 的 value 是 该 选项 所 代表 对 应 的 选择 值 ， 可 以 省 略 


回 


跳 转 菜单 


<select name="menul" onchange="MM _jumpMenu(parent .this.0)"> 
<option>unnamed1</option> 
</select> 


跳 转 菜 单 ， 通 过 表单 实现 指定 网 址 之 间 的 跳 转 


图 像 域 


<input type="image" name="imageField" src="images/QQ.gif" > 在 表单 中 插入 图 片 


文件 域 


<input type="file" name="file" /> 完成 文件 的 提交 


口 回回 


按钮 


<input type="submit" name="Submit" value=" 提 交 " /> 创建 的 提交 按钮 ,如 果 type 的 值 为 button， 
那么 它 表示 一 个 普通 的 按钮 ， 不 具备 提交 的 功能 
<input type="reset" name="Submit2" value=" 重 置 " /> 创建 的 重 置 按钮 


标签 


<labe 上 > 标签 </label> 


口 国 


字段 集 


<fieldset><legend> 字 段 集 </legend></fieldset> 


41 


PHP 开发 实例 大 全 (基础 卷 ) 
图 设计 过 程 
在 Dreamweaver 中 创建 表单 的 操作 步骤 如 下 : 


(1) 新 建 一 个 动态 PHP 文件 ， 切 换 到 设计 模式 下 。 
(2) 在 工具 栏 中 选择 “表单 ”选项 ， 如 图 1.92 所 示 。 


EDEI-LTYaJ lallalallelele)lea 
图 1.92 选择 表单 工具 
(3) 添加 一 个 form 表单 ， 如 图 1.93 所 示 。 
Egaaagaaaasaasas 

图 1.93 添加 表单 

(4) 根据 实际 需要 ， 添 加 不 同 的 表单 元 素 ， 并 设置 相应 的 名 称 和 值 ， 如 图 1.94 所 示 。 

EL | | 
图 1.94 添加 表单 元 素 

最 终 创建 的 表单 元 素 设计 效果 如 图 1.95 所 示 。 


:| 网 音乐 厂 体育 三 文学 
:|C 男 CC 女 
C PHP 


:| C Jama 


C vB 


1.95 表单 元 素 的 设计 效果 
国 秘笈 心 法 


心 法 领悟 023: 通过 表单 传 值 时 的 注意 事项 。 

在 通过 表单 中 的 元 素 传递 值 的 时 候 ， 一 定 要 正确 地 书写 表单 元 素 的 名 称 ， 其 中 不 应 该 有 空格 存在 ; 在 获取 
表单 元 素 的 值 时 ， 表 单元 素 的 名 称 一 定 要 与 form 中 设置 的 名 称 相同 ， 同 时 还 要 注意 大 小 写 的 统一 ， 否 则 将 不 能 
获取 到 表单 元 素 的 值 。 


实 建 和 附加 CSS 样式 了 | 
国 实例 说 明 


本 实例 讲解 如 何在 Dreamweaver 中 创建 和 附加 CSS 样式 。 通过 CSS 能 够 更 好 地 对 网 页 中 的 表格 、 文本 和 图 
像 的 样式 进行 控制 ， 并 且 使 其 更 易于 维护 和 更 新 。 本 实例 的 运行 结果 如 图 1.96 所 示 。 
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编程 词典 言传 语 总 结 


二 计生 可 请 和 的 “ 亲 和 守 和 典 ”” 具 各 海量 的 到 和 资源 * 天助 您 解 在 学 习 办 
程 香 言 中 退 到 的 问题 - 


(2) 碟 程 者 的 良 病 益 友 - 为 起 的 插 习 提供 完 问 的 皖 习 方 案 ， 失意 提供 理论 和 实践 相 结合 
的 机 会 ( 字 习 方法 、 实 例 、 实 跨 竺 习 ) 


Cd 
可 以 作为 参考 ， 也 可 以 直接 使 用 - 《 方案 、 程 序 》 


(4) 完美 的 售后 服务 和 交互 方式 - 9、 电 话 、 FRAIL 


1.96 ”Dreamweaver 中 创建 和 附加 CSS 样式 


图 关键 技术 


在 Dreamweaver 中 创建 CSS 样式 ， 必 须 明确 新 建 CSS 样式 的 规则 ， 如 图 1.97 所 示 。 


新 建 css 


we c Ca 


图 1.97 新建 CSS 规则 


如 果 选 中 “新 建 样式 表 文 件 ) ” 单 选 按 钮 ， 那 么 定义 的 CSS 存储 于 指定 的 文件 夹 下 ; 如 果 选 中 “ 仅 对 该 
文档 ” 单 选 按钮 ， 那 么 定义 的 CSS 存储 于 该 文件 中 。 

如 果 只 是 对 单独 的 某 个 文件 进行 操作 ， 建 议 将 CSS 定义 到 当前 文件 中 ， 但 是 ， 如 果 是 在 网 站 中 应 用 CSS， 
那么 应 该 将 CSS 样式 定义 到 单独 的 文件 中 ， 并 且 以 类 的 形式 进行 定义 ， 因 为 这 样 便于 对 CSS 样式 的 修改 ， 使 网 
站 的 样式 更 加 统一 ， 而 且 可 以 避免 代码 的 元 余 。 

图 设计 过 程 

创建 一 个 名 称 为 styles 的 样式 ， 将 其 定义 到 新 建 样式 表 中 ， 使 用 类 的 形式 进行 定义 ， 其 具体 的 操作 步 又 
如 下 : 

(1) 在 Dreamweaver 的 设计 模式 下 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ”/“ 新 建 ” 命 令 ， 在 弹出 
的 “新 建 CSS 规则 ”对 话 框 中 定义 CSS 样式 的 规则 ， 如 图 1.98 所 示 。 

(2) CSS 样式 的 规则 定义 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 弹 出 “保存 样式 表 文件 为 ”对 话 框 ， 定 义 CSS 样 
式 文件 的 存储 位 置 ， 如 图 1.99 所 示 。 


选取 立 件 画 自 Se 让 点 和 服务 器 
RED [ce OF 
新 建 css 规则 划 
毕 近 器 闫 型。 个 类 可 应 用 于 任何 标签 ) 他) 文件 各 WD; eles 保存 (8) 
内 me 守 O 地 油 人 DR ec | 
5 可 | 
[CR mo 对 
二 对 蛮 交 格 定义 中 在 隐 扶 认 的 洲 返 柜 于 a 
1.98 定义 CSS 样式 的 规则 1.99 定义 CSS 样式 表 的 存储 位 置 


(3) 确定 存储 位 置 和 名 称 后 ， 单 击 “ 保 存 ” 按 钮 ， 将 弹出 styles 样式 具体 的 规则 定义 对 话 框 ， 如 图 1.100 
所 示 。 在 其 中 ， 可 以 根据 “分 类 ”， 对 类 型 、 背 景 、 区 块 、 方 框 、 边 框 、 列 表 、 定 位 和 扩展 分 别 进行 定义 ， 单 
击 “ 确 定 ”按钮 ，styles 样式 创建 完成 。 
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le， 的 CSS 规 宇 咏 ( 在 Stylescss 中 
2 Ee 
启 放 人 外; 刁 
a A 
| wm:"— 可 
Re | Ce Ee | 
亿 册 四- 厂 下 0D OF 

厂 起 大 四 

厂 最 际 二 加 

[0 

[是 工 

CE ww | 四 日 | wm 


图 1.100 定义 styles 样式 的 规则 


(4) 在 Dreamweaver 的 设计 模式 下 ， 选 中 被 操作 的 内 容 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ” 命 
令 ， 即 可 选择 指定 的 样式 文件 ， 如 图 1.101 所 示 。 


篇 程 词典 言传 语 总 结 : 
上 | 向 本 69 而 “新 和 于 下 ”下 者 向 到 到 表 大 末了 和 犁 天 在 于 可 转 各 本 下 天 到 的 有 


ES | 
EE 下 证 页 面 、 丰 到 有 胃 讶 砍 害 。 可 以 作为 吉村 


1.101 ”应 用 定义 的 CSS 样式 


妈 9 技巧 : 附加 CSS 样式 文件 。 在 Dreamweaver 的 设计 模式 下 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ”/ 
“附加 样式 表 ” 命 令 ， 在 弹出 的 “链接 外 部 样式 表 ” 对 话 框 中 可 选择 定义 在 指定 文件 天 下 的 CSS 样 
式 文件 。 如 果 选 择 “ 链 接 ”, 则 直接 通过 link 标签 链接 到 CSS 样式 文件 ;如 果 选 择 导 入 , 则 通过 @import 

url 导入 指定 的 CSS 文件。 确定 附加 的 CSS 样式 文件 后 ， 单 击 “ 确 定 ” 按 钮 。 


国 秘 稚 心 法 


心 法 领悟 024: 在 Dreamweaver 中 创建 CSS 样式 的 相关 说 明 。 


在 Dreamweaver 中 创建 的 CSS 样式 , 可 以 在 代码 模式 下 对 其 进行 修改 , 也 可 以 在 设计 模式 下 对 其 进行 修改 ， 
如 图 1.102 所 示 。 


图 1.102 在 设计 模式 下 操作 CSS 样式 
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实例 025 


力 实例 说 明 


在 Dreamweaver 中 不 但 可 以 创建 表格 、 表 单 或 者 CSS 样式 等 内 容 ， 而 且 可 以 通过 行为 ， 实 现 一 些 特殊 的 
功能 。 例 如 ， 在 本 实例 中 定义 一 个 “弹出 信息 ”行为 ， 当 用 户 单 击 指定 的 图 片 时 ， 将 弹出 一 个 提示 对 话 框 ， 


如 图 1.103 所 示 。 
;证 请 的 个 人 知客 


雯 用 FP 汪 骨 


会 员 名 称 : | 


和 介 : | 
十 人 要好 
性 别 : 


[3 
ET 


Copyright 1999-2010 吉林 省 明 日 科技 有 限 公司 


图 1.103 ”通过 Dreamweaver 直接 创建 的 弹出 信息 


图 关键 技术 


在 Dreamweaver 中 控制 弹出 信息 的 原理 是 自动 创建 JavaScript 脚本 文件 ， 定 义 方法 ， 然 后 通过 onclick 调用 
脚本 中 的 方法 ， 完 成 当 鼠 标 单 击 指定 的 内 容 时 弹出 信息 。 


JavaScript 脚本 中 定义 的 方法 如 下 : 

‘<script type="text/JavaScript"> 

<!-- 

function MM_popupMsg(msg) { //v1.0 
alert(msg); 


在 表单 的 图 像 域 中 ， 通 过 onclick 事件 完成 对 脚本 文件 方法 的 调用 ， 其 代码 如 下 : 
<input name="imageField" type="image" onclick="MM_popupMsg(' 请 输入 完整 的 注册 信息 )" src="images/09jpg" /> 
图 设计 过 程 
在 Dreamweaver 中 添加 “弹出 信息 ”行为 的 操作 步骤 如 下 : 
(1) 通过 Dreamweaver 新 建 一 个 index.php 文件 ， 创 建 一 个 用 户 注册 页 面 。 
(2) 在 Dreamweaver 的 设计 模式 下 , 选择 用 户 注册 的 图 像 域 , 然后 选择 “窗口 /行为 ”命令 , 在 Dreamweaver 
操作 界面 的 右 侧 将 弹出 如 图 1.104 所 示 的 内 容 。 
(3) 在 图 1.104 所 示 的 界面 中 , 单 击 到 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “弹出 信息 ”选项 , 将 弹出 如 图 1.105 
所 示 的 “弹出 信息 ”对 话 框 ， 在 “消息 ”文本 框 中 定义 弹出 信息 的 内 容 ， 最 后 单 击 “确定 ”按钮 ， 弹 出 信息 的 


栈 
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行为 创建 完毕 。 
a 司 CJ] 
避 bk 
图 1.104 行为 控制 面板 图 1.105 编辑 弹出 信息 


心 法 领悟 025: 在 Dreamweaver 中 实现 一 些 JavaScript 功能 。 


在 Dreamweaver 中 , “弹出 信息 ”只 是 众多 行为 中 的 一 个 ， 还 可 以 通过 “窗口 ”中 的 行为 实现 很 多 的 功能 ， 
如 图 1.106 所 示 。 


实例 026 趣味 指数 : 址 走 址 窜 


力 实例 说 明 


本 实例 将 介绍 Dreamweaver 中 行为 的 另 一 种 功能 一 一 控制 打开 浏览 器 的 窗口 。 通 过 该 功能 可 以 对 打开 的 浏 
览 器 窗口 进行 设置 ， 包 括 窗 口 的 高 度 、 宽 度 以 及 是 否 包含 导航 工具 栏 、 地 址 工具 栏 和 菜单 栏 等 ， 本 实例 的 运行 
结果 如 图 1.107 所 示 。 


< 控制 浏 寅 要 打开 全 口 -microswEE EREEEGGE 


Er ety: t/t.0.0.1 fae /0/02L/ inde ok ph | | 


PR 


| 多 用 P 渤 册 
52: 
前 仙 : | 于 十 入 态 的 下 人 信息 四 


。 个 人 过 好 : 网 音 和 张 厂 体育 厂 立 学 
| 性 淖 3 个 男 全 女 


语言 夫 择 - C Jove 


”图书 迁 择 : |PHF 开 发 支 此 主 具 可 


| 过 ET 
1.107 Dreamweaver 控制 浏览 器 的 窗口 
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图 关键 技术 


控制 打开 浏览 器 的 窗口 同样 是 Dreamweaver 中 行为 的 一 种 功能 , 通过 该 功能 可 以 控制 网 页 窗口 的 打开 模式 。 
例如 ， 网 页 窗口 中 导航 条 的 使 用 、 滚 动 条 的 使 用 、 地 址 工具 栏 的 应 用 以 及 网 页 窗口 的 大 小 等 。 
行为 中 “打开 浏览 器 窗口 ”的 操作 界面 如 图 1.108 所 示 。 


RL | 
om Fr ae 0 —mw | 


图 1.108 “打开 浏览 器 窗口 ”对 话 框 
设计 过 程 
在 Dreamweaver 中 添加 “打开 浏览 器 窗口 ”行为 的 操作 步骤 与 添加 “弹出 信息 ”行为 是 相同 的 ， 唯 一 的 区 
别 是 在 单 击 至 按钮 时 ， 在 弹出 的 下 拉 菜 单 中 选择 “打开 浏览 器 窗口 ”命令 ， 将 弹出 如 图 1.108 所 示 的 “打开 浏览 
器 窗口 ”对 话 框 。 
秘笈 心 ; 
心 法 领悟 026: 在 Dreamweaver 中 屏蔽 标准 按钮 。 


通过 “打开 浏览 器 窗口 ”行为 ， 可 以 屏蔽 浏览 器 窗口 中 的 标准 按钮 ， 这 个 功能 在 某 些 程序 中 是 非常 有 用 的 。 
例如 ， 在 一 些 需要 屏蔽 刷新 功能 的 网 页 中 ， 通 过 “打开 浏览 器 窗口 ”行为 来 实现 是 比较 不 错 的 方法 。 


趣味 指数 : oodotodl 
用 实例 说 明 

本 实例 讲解 如 何在 Dreamweaver 中 创建 站 点 ， 从 而 不 必 在 下 浏览 器 中 输入 地 址 ， 只 需 按 F12 键 , 即 可 完成 
对 所 创建 程序 的 浏览 操作 。 


图 关键 技术 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 ,一定 要 注意 将 本 地 的 HITP 地 址 与 测试 服务 器 中 的 URL 
前 缀 统一 ， 即 都 指定 到 站 点 的 根 目录 下 。 例 如 ， 指 定 HITP 的 地 址 是 http://localhost/mr/01/， 那 么 测试 服务 器 的 
URL 前 级 也 必须 是 http://localhost/mr/01/ 或 者 http://127.0.0.1/mr/01/。 


图 设计 过 程 

在 Dreamweaver 中 创建 站 点 的 操作 步骤 如 下 : 

(1) 打开 Dreamweaver 开发 工具 ， 选 择 菜单 栏 中 的 “站 点 ”/“ 新 建站 点 ”命令 ， 在 弹出 的 如 图 1.109 所 示 
对 话 框 中 添加 站 点 名 称 、 设 置 本 地 根 文件 夹 、 链 接 相 对 于 “站 点 根 目录 ”、 设 置 HITP 地 址 。 


(2) 选择 左 侧 的 “测试 服务 器 ”选项 ,进入 如 图 1.110 所 示 的 “测试 服务 器 ”对 话 框 ,选择 服务 器 模型 PHP 
MySQL， 访 问 为 “本 地 /网 络 ”， 测 试 服务 器 文件 夹 为 F\PkhPHP\www\，URL 前 组 为 http://localhost/， 最 后 单 
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击 “ 确 定 ” 按 钮 。 


万 新 不 地 文 补 列 表册 
默认 图 像 立 件 到 人 已 


测试 报名 器 
脏 接 相对 于 ; 信玄 档 罩 ) 人 站 点 朴 目 录 E) 
7 PEP? Te | 
和 ago Ev 
5X 关 ia 口 
区 分 大 小写 的 猎 接 ; 厂 使 用 区 分 大 十 写 的 哇 按 梯 查 0) 厂 目 动 得 新 测试 娘 六 列表 呈 ) 
生存 ; 厂 局 用 经 存 E) 最 mr 
CE | | Ci wy | ww | 
图 1.109 定义 mr 站 点 图 1.110 配置 测试 服务 器 


(3) mr 站 点 和 测试 服务 器 设置 完毕 后 ， 就 可 以 在 Dreamweaver 下 直接 使 用 F12 键 来 浏览 程序 了 。 
心 法 领悟 027: 在 Dreamweaver 中 创建 站 点 的 注意 事项 。 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 , 如 果 本 地 的 HTTP 地 址 与 测试 服务 器 中 的 URL 前 级 不 统 
一 ， 那 么 就 不 能 够 通过 F12 键 直接 浏览 程序 。 


过 开发 第 1 个 PHP 程序 中 级 | 
实例 028 趣味 指数 : holed 
力 实例 说 明 


前 面 实例 讲 解 了 Dreamweaver 自身 功能 的 运用 ,在 本 实例 中 应 用 Dreamweaver 开发 一 个 最 简单 的 PHP 程序 ， 
即 输 出 一 段 欢迎 信息 ， 其 目的 一 是 了 解 PHP 的 语法 规则 ， 二 是 熟悉 Dreamweaver 开发 工具 的 使 用 。 运 行 结果 如 
图 1.111 所 示 。 


济 第 一 个 PiF 程 序 ~ Wicrosoft Interaedzo700 


文件 @) 编辑 EE) 查看 WW) 收藏 和 ) 工具 上 竹 > rr 
地 址 甸 | 智 http: //127.0.0. 1/mr/01/028/ 司 BE ED » 


| wim 和 pa 办! FE 
BE 厂矿 于 


图 1.111 第 1 个 PHP 程序 


图 关键 技术 


必须 将 通过 Dreamweaver 开发 工具 编写 的 PHP 脚本 ， 存 储 到 PHP 开发 环境 指定 的 服务 器 文件 夹 下 才 可 


力 设计 过 程 
(1) 打开 Dreamweaver 开发 工具 ， 新 建 一 个 PHP 项 目 ， 如 图 1.112 所 示 。 
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图 1.113 新 的 PHP 项 目 文件 


(3) 在 图 1.113 所 示 的 文件 中 , 首先 定义 文件 的 标题 <title> 第 一 个 PHP 程序 </title>, 然后 编写 PHP 代码 ， 
其 代码 如 下 : 
< 


php 
echo "欢迎 进入 PHP 的 世界 ! “ 
> 


PHP 代码 分 析 : 


“<?php” 和 “?>” 是 PHP 的 标记 对 。 在 这 对 标记 中 的 所 有 代码 都 被 当 作 PHP 代码 来 处 理 。 
echo 是 PHP 中 的 输出 语句 ， 与 ASP 中 的 response.write、JSP 中 的 out.print 含义 相同 ， 输 出 字符 串 或 
者 变量 值 。 每 行 代码 都 以 分 号 “;” 结 尾 。 


(4) 保存 文件 ， 选 择 图 1.113 中 的 “文件 ”/“ 另 存 为 ”命令 ， 将 编写 的 文件 保存 在 站 点 的 根 目录 www 文 
件 夹 中 ， 并 命名 为 testphp， 最 后 单 击 “ 保 存 ” 按 钮 ， 如 图 1.114 所 示 。 
力 秘笈 心 法 
心 法 领悟 028: 运行 程序 的 两 种 方法 。 
程序 的 运行 有 两 种 方法 : 第 一 种 ， 直 接 在 Dreamweaver 开发 工具 中 按 F12 键 运行 程序 ; 第 二 种 , 在 正 浏 览 
器 的 地 址 栏 中 输入 http://127.0.0.1/test.php。 程 序 运行 的 前 提 是 必须 将 程序 存储 到 服务 器 指定 的 文件 夹 中 。 
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EE 
口 生 已 四 - 


图 1.114 保存 编写 的 PHP 文件 


1.7 Zend Studio 开发 工具 


Zend Studio 是 目前 比较 流行 的 PHP 开发 工具 ， 襄 括 了 编辑 、 调 试 、 配 置 PHP 程序 所 需要 的 客户 及 服务 器 
组 件 ， 尤 其 是 功能 齐全 的 调试 功能 ， 让 PHP 错误 不 再 棘手 。 

Zend Studio 也 有 不 足 之 处 ， 一 是 运行 速度 慢 ; 二 是 没有 Dreamweaver 的 界面 设计 功能 ， 只 能 通过 浏览 器 来 
浏览 页 面 设计 效果 ; 三 是 其 是 一 款 收费 软件 (但 可 以 下 载 试用 版 )， 下 载 地 址 为 http://www.zend.conystore/ 
products/zend-studio.php 。 


二 中 级 
图 实例 说 明 


在 应 用 Zend Studio for Eclipse 之 前 ， 我 们 有 必要 介绍 一 下 它 的 安装 步骤 ， 因 为 只 有 正确 地 完成 安装 ， 才 能 
够 顺利 地 应 用 。 


力 关键 技术 


在 安装 Zend Studio for Eclipse 的 过 程 中 , 关键 是 安装 内 容 的 选择 、 安装 位 置 的 选择 和 定义 Zend 支持 的 文件 
格式 ， 这 是 在 安装 过 程 中 必须 注意 的 内 容 。 


图 设计 过 程 
(1) 运行 安装 文件 ， 进 行 安装 准备 工作 ， 如 图 1.115 所 示 。 


CC 


[C}2002.2006 Macrovison Europe Léand/or Macowsion Corporstion 


图 1.115 安装 Zend Studio for Eclipse 的 准备 工作 
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(2) 进入 安装 界面 ， 如 图 1.116 所 示 ， 单 击 Next 按钮 。 
(3) 进入 阅读 服务 器 条 款 对 话 框 ， 选 择 同意 ， 如 图 1.117 SR 单 击 Next 按钮 。 


ee 
Stdio for Eclipse 


lekine Nod nutono croceodts a nosereon Fycu yat 
hange something on 3 prevous seroen, olectne Pravous’ curnn 
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图 1.116 开始 进行 安装 图 1.117 阅读 服务 条 款 


(4) 在 选择 安装 内 容 对 话 框 中 包括 一 个 Zend 浏览 器 和 Zend Studio， 两 项 全 部 选中 ， 如 图 1.118 所 示 。 单 
击 Next 按钮 ， 进 入 下 一 步 。 

(5) 在 进入 的 对 话 框 中 设置 文件 的 安装 目录 ， 用 户 可 以 任意 指定 安装 位 置 ， 确 定 后 单 击 Next 按钮 进行 下 
一 步 ， 如 图 1.119 所 示 。 


FP Quck Loynen oatar 


oebugget and cronler and robuat sooe 5omp en 
PHP canatmuets ne weli an HTML 


1.118 选择 安装 内 容 1.119 设置 工具 安装 位 置 


(6) 在 进入 的 定义 Zend 支持 的 文件 格式 对 话 框 中 ， 全 部 选中 ， 如 图 1.120 所 示 。 
(7) 确认 安装 信息 ， 如 图 1.121 所 示 ， 单 击 Install 按钮 开始 进行 安装 。 


Please review the follewing infermation 


Proguct Name: 
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图 1.120 定义 Zend 支持 的 文件 格式 1.121 确认 安装 信息 


of 
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(8) 安装 进行 中 ， 如 图 1.122 所 示 。 
(9) 安装 完成 ， 单 击 Done 按钮 ， 如 图 1.123 所 示 。 


Installing Zend Studio for Eclipse -6.1.1 
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图 1.122 Zend 安装 进行 中 图 1.123 ”安装 成 功 
这 就 是 Zend Studio for Eclipse 的 安装 ， 过 程 非常 简单 ， 但 是 等 待 的 时 间 较 长 。 
图 秘笈 心 法 
心 法 领悟 029: 选择 工作 空间 。 


运行 Zend Studio for Eclipse， 可 以 选择 File/Switch Workspace 命令 来 选择 工作 的 空间 ， 或 者 重新 创建 工作 
空间 ， 如 图 1.124 所 示 。 


) workspace Launcher x| 


Select a workspace 


Zend Studio stores your projects In a folder called a workspace. 
Choose a workspace folder to use for this session, 


Workspace: [BE -| Browse | 
* Copy Settings 
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图 1.124 创建 工作 空间 


中 级 | 
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实例 030 


力 实例 说 明 


本 实例 介绍 如 何 通过 Zend Studio 创建 PHP 项 目 。 在 本 项 目 中 创建 一 个 PHP 文件 ， 通 过 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 其 运行 结果 如 图 1.125 所 示 。 


国 关键 技术 


通过 Zend Studio 编写 PHP 程序 ， 首 先 要 选择 正确 的 工作 空间 ， 如 果 工 作 空间 选择 不 正确 ， 那 么 PHP 的 程 
序 就 无 法 运行 。 


> 
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图 1.125 运行 程序 


用 设计 过 程 


(1) 运行 Zend Studio， 首 先进 入 Zend Studio 的 欢迎 页 面 ， 如 图 1.126 所 示 。 


Welcome to Zend Studio for Eclipse 僵 = 


5 Ways to Get started with zend studio for 
Eclipse 


7 Create a zend Eramaewtork Example Working mkh tho profler 
projoct Working with Rotactoring 
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Working with cvs 
Working with SYN 


1.126 进入 Zend Studio 欢迎 页 面 


(2) 选择 “文件 ”/“ 切 换 工作 空间 ”/“ 其 他 ”命令 ,设置 工作 空间 ， 将 项 目 保存 在 指定 名 称 的 文件 夹 中 ， 
如 图 1.127 所 示 ， 将 F:\PkKhPHPWwww 文件 夹 作 为 工作 空间 。 


先锋 工作 室 间 
下 全 让 各 力 基 工作 富 的 区 件 关 中 


1.127 选择 工作 空间 
(3) 接 下 来 进入 Zend Studio 的 工作 台中 ， 如 图 1.128 所 示 。 
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图 1.128 ”Zend Studio 的 工作 台 
(4) 创建 一 个 PHP 项 目 。 选择“ 文件 ”/“ 新 建 ”/PHP Project 命令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.129 所 示 。 


图 1.129 创建 PHP 项 目 


(5) 进入 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 值 ; 


1.130 新建 项 目 
(6) 在 项 目 01 中 创建 PHP 文件， 如 图 1.131 所 示 。 


%® 
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1.131 创建 PHP 文件 


在 图 1.129 所 示 的 操作 步 又 中 ， 不 但 可 以 创建 PHP 文件 ， 还 可 以 创建 HTML、CSS、JavaScript 和 XML 文 
件 等 ， 具 体 可 以 根据 程序 的 实际 情况 进行 创建 。 
(7) 进入 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 Finish 按钮 ， 如 图 1.132 所 示 。 


图 1.132 创建 index.php 文件 
(8) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 ， 如 图 1.133 所 示 。 


fer Religie 


图 1.133 编辑 PHP 代码 
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如 图 1.133 所 示 ，Zend Studio for Eclipse 工具 最 大 的 优点 就 是 代码 提示 功能 ， 它 可 以 在 用 户 输入 部 分 PHP 
脚本 语言 时 ， 给 出 相关 PHP 脚本 语言 的 提示 供 选择 。 这 里 应 用 phpinfo0 函 数 获取 PHP 的 相关 配置 信息 。 
(9) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 殉 按 钮 ， 运 行程 序 ， 运 行 结果 请 参看 实例 说 明 。 


心 法 领悟 030: Zend Studio 对 Zend Framework 框架 的 支持 。 


通过 Zend Studio 不 但 可 以 创建 PHP 项 目 ， 而 且 可 以 直接 生成 Zend Framework 框架 ， 开 发 者 不 必 再 为 搭建 
Zend Framework 框架 而 头疼 。 


实例 031 趣味 指教 : 请 请 请 容 | 
图 实例 说 明 


在 Zend Studio 中 同样 可 以 控制 创建 项 目 、 文 件 的 编码 格式 ， 至 于 编码 格式 选择 的 重要 性 这 里 不 再 浆 述 。 下 
面 介绍 如 何在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 。 如 果 通 过 Zend Studio 打开 一 个 编码 格式 不 匹配 的 文 
件 ， 输 出 结果 如 图 1.134 所 示 。 


!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transicional//EN”" 加 
2 <html xmlns="http://www.w3. org/1999/xhtmi"> 
Si<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf- 
5 <title>Dreamweaver 银 y 起 娴 届 ” 错 儿 寺 窜 [给 权 肥 </tic1e> 
6 <link href="css/styles.css" rel="stylesheet" type="text/css" /> 
7 日 <acripr type="text/Javascript"> 
8 <!-- 
9 function NM popupMsg(msg) { //v1.0 
alert (msg); 
} 
2 //--> 
</script> 


</head> 
4 


图 1.134 ”编码 格式 不 正确 导致 乱码 


力 关键 技术 


在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 ， 关 键 是 从 根本 着 手 ， 也 就 是 说 要 控制 一 个 项 目 中 文件 的 编码 
格式 ， 只 要 项 目 本 身 的 编码 格式 确立 ， 那 么 创建 的 文件 格式 自然 是 与 项 目 相同 的 。 


图 设计 过 程 

(1) 在 Zend Studio 中 要 设置 项 目的 编码 格式 ， 首 先 就 要 创建 一 个 项 目 。 有 关 项 目 创 建 的 具体 步骤 请 参看 
实例 030， 这 里 不 再 效 述 。 

(2) 项 目 创建 成 功 后 , 选中 创建 的 项 目 , 右 击 , 在 弹出 的 快捷 菜单 中 选择 Properties 命令 , 弹出 如 图 1.135 
所 示 的 窗口 。 

(3) 在 该 窗口 中 选中 Other 单 选 按 钮 ， 在 其 下 拉 列 表 中 选择 指定 的 编码 格式 ， 最 后 单 击 OK 按钮 ， 项 目 编 
码 格式 即 设置 完成 。 
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由 -Code Style Dype: Project 
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Text file encoding 
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图 1.135 设置 项 目的 编码 格式 


国 秘笈 心 法 

心 法 领悟 031: 在 Zend Studio 中 修改 编码 格式 。 

在 实例 说 明 中 我 们 曾 看 到 一 个 编码 格式 不 匹配 的 文件 打开 的 效果 ， 那 么 如 何 对 这 个 文件 的 编码 格式 进行 修 
改 呢 ? 

首先 ， 打 开 编 码 格式 不 匹配 的 文件 。 然 后 单 击 Edit 按钮 ， 在 弹出 的 菜单 中 选择 Set Encoding 命令 ， 将 弹出 
如 图 1.136 所 示 的 对 话 框 , 在 这 个 对 话 框 中 选中 Other 单 选 按 钮 , 设置 这 个 文件 的 编码 格式 。 最 后 单 击 OK 按钮 。 


© Default (GBK) 
他 Other: Nre-s] S| 
wy | en | 


1.136 设置 文件 的 编码 格式 


要 & 键 的 运用 中 级 | 


力 实例 说 明 
在 Zend Studio 中， 通过 快捷 键 可 以 完成 很 多 操作 ， 快 捷 键 的 运用 可 以 为 开发 者 节省 很 多 时 间 ， 而 且 可 以 简 
化 操作 的 流程 。 在 本 实例 中 将 介绍 如 何 运用 Zend Studio 中 的 快捷 键 创建 PHP 项 目 。 


图 关键 技术 

要 应 用 Zend Studio 中 的 快捷 键 ， 必 须 了 解 快捷 键 代表 的 意义 。 在 Zend Studio 中 ， 选 择 “ 帮 助 ”/Key Assist 
命令 将 弹出 Zend Studio 中 的 快捷 键 列表 ， 或 者 也 可 以 直接 按 Ctrl+Shift+L 键 ， 同 样 可 以 弹出 快捷 键 列表 。 在 这 
个 列表 中 可 以 查看 到 所 有 快捷 键 代表 的 意义 ， 如 图 1.137 所 示 。 


PHP 开发 实例 大 全 (基础 着) 
pienson pe Cr 
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看 设计 过 程 
(1) 在 Zend Studio 中 创建 一 个 PHP 项 目 。 可 以 直接 使 用 快捷 键 Alt+ShifttrN， 将 弹出 一 个 菜单 命令 列表 ， 
选择 PHP Project 命令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.138 所 示 。 


图 1.138 创建 PHP 项目 


(2) 进入 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 值 ; 
选择 PHP 的 版 本 ， 设 置 是 否 支持 JavaScript 脚本 ， 如 图 1.139 所 示 。 


1.139 新 建 项 目 
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(3) 在 项 目 01 中 创建 PHP 文件 。 编写 一 个 简单 实例 ,同样 可 以 使 用 快捷 键 Alt+Shiftt+rN， 只 是 要 在 列表 中 
选择 PHP File 命令 ， 如 图 1.140 所 示 。 
(4) 进入 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 Finish 按钮 ， 完 成 文件 的 创建 ， 如 图 1.141 所 示 。 


ES 


BH Nanter I 3 T_T 至 I 


1.140 创建 PHP 文件 


Source Folder |/01 


File Nane ~ [index| php 


Next > Einish 


图 1.141 创建 index.php 文件 


(5) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 。 在 编辑 区 中 可 以 通过 快捷 键 Ctl+ShifttF 对 代 
码 进行 格式 化 ， 如 图 1.142 所 示 。 


S9 
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phpinfo0 函 数 的 提示 


四 | | pl smovens [Tashe | corece [WM serverr | » Deo Ovo 5 习 
图 1.142 编辑 PHP 代码 
(6) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 网 | 按钮， 运行 程序 ， 运 行 结果 如 图 1.125 所 示 。 
图 秘笈 心 法 


心 法 领悟 032: 在 Zend Studio 中 使 用 快捷 键 。 
在 Zend Studio 中 ,对 于 快捷 键 的 使 用 不 必 机 械 地 去 记忆 ， 只 要 了 解 一 些 常用 的 快捷 键 即 可 。 对 于 初学 者 来 
说 ， 通 过 鼠标 进行 操作 比 使 用 快捷 键 更 好 ， 更 有 助 于 对 工具 功能 的 理解 和 学 习 。 


中 级 
趣味 指数 : 富 坪 商 容 


力 实例 说 明 


在 运行 PHP 程序 的 过 程 中 , 需要 将 PHP 程序 复制 到 Apache 服务 器 指定 的 根 目录 下 , 然后 在 正 浏览 器 的 地 
址 栏 中 输入 Le //127.0.0. 和 http: /localhost 来 运 云 行 行 PHP 程序 。 而 在 Zend Studio 中 可 以 直接 部 署 Apache 服 


HD A OED so 
je IB /TID.0.8. 
J 


四 /J 本 于 和 = 


jm I 加 
图 1.143 运行 程序 
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图 关键 技术 


在 Zend Studio 中 部 署 Apache 服务 器 ， 关 键 是 指定 正确 的 访问 路 径 ， 如 图 1.144 所 示 。 
和 


Er 
-ll 
| 


0 


(| Filter natehed 5 of 6 itens 


图 1.144 部 署 Apache 服务 器 的 访问 路 径 
如 果 在 图 1.144 所 示 的 界面 中 ， 没 有 指定 URL 中 访问 文件 的 具体 位 置 MR/01/001， 那 么 程序 就 不 能 正常 运 
行 ， 将 出 现 如 图 1.145 所 示 的 效果 。 


| 司 并 不 到 网 页 
您 要 查看 的 网 页 可 能 已 被 前 除 、 名 称 己 被 更 疏 ， 或 者 暂时 不 可 用 。 


请 尝试 以 下 操作 : 
。 加 果 您 已 经 在 地 址 栏 中 输入 该 网 页 的 地 址 ， 诸 确认 其 拼写 正确 。 
。 打开 localhost 主页 ， 热 后 查找 指向 您 感 兴趣 信息 的 链接 . 


， 尝试 其 他 链接 。 
， 寻找 Internet 上 的 信息 。 


J0TP 404 - 未 找到 文件 
TInternet Explorer 


图 1.145 未 指定 URL 访问 路 径 


力 设计 过 程 
在 Zend Studio 中 部 署 Apache 服务 器 的 操作 步 又 如 下 : 


(1) 创建 一 个 PHP 项目， 这 里 不 再 袭 述 。 
(2) 单 击 工具 栏 中 加 3 按钮 的 下 三 角 按钮 ， 将 弹出 一 个 下 拉 菜单 ， 选 择 Run Configurations 选项 ， 在 弹 
出 的 对 话 框 中 完成 对 Apache 服务 器 的 部 署 ， 包 括 文件 的 指定 ， 如 图 1.146 所 示 。URL 访问 路 径 的 设置 ， 如 


图 1.147 所 示 。 
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四 Cs 
-== 


图 1.146 设置 访问 文件 图 1.147 设置 URL 访问 路 径 
(3) 设置 完成 后 单 击 Run 按钮 ， 即 可 浏览 PHP 项 目 中 的 内 容 。 
笈 心 法 
心 法 领悟 033: 在 Zend Studio 中 修改 快捷 键 的 设置 。 


单 击 Window 按钮 ， 然 后 选择 Preferences 命令 ， 将 弹出 如 图 1.148 所 示 的 窗口 ， 可 以 在 其 中 完成 对 快捷 键 
的 修改 操作 。 
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图 1.148 ”Zend Studio 中 快捷 键 的 修改 步骤 
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基本 语法 
运算 符 
包含 语句 
条 件 语句 
循环 语句 
跳 转 语句 
自 定 义 轩 数 
字符 果 
正则 表达 式 
数组 
日 期 和 时 间 
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2.1 基本 语法 


也 许 你 是 一 个 PHP 初学 者 ， 当 你 向 有 经 验 的 PHP 高 级 程序 员 请 教 如 何 学 好 PHP 这 门 语 言 时 ， 想 必 他 会 问 
你 有 没有 其 他 编程 语言 的 基础 ， 如 果 有 的 话 ， 就 能 够 很 快 入 门 ， 学 起 来 也 很 轻松 。 

由 此 可 见 ， 掌 握 一 门 语言 是 多 么 的 重要 。 可 以 说 ， 扎 实 的 语言 基础 ， 是 培养 和 提高 程序 员 编程 能 力 的 基本 
途径 ,语言 基础 也 是 学 习 PHP 过 程 中 非常 重要 的 一 个 环节 , 它 在 很 大 程度 上 决定 了 程序 员 PHP 学 习 的 进展 效果 。 

另外 ， 程 序 员 的 创造 力 极 强 ， 可 以 完全 按照 自己 的 设计 目标 和 思路 组 织 代码 ， 用 与 其 他 程序 员 完全 不 同 的 
设计 方法 实现 完全 相同 的 功能 。 但 是 ， 编 程 同时 也 是 一 项 十 分 严谨 的 工作 ， 因 为 语法 是 严格 限定 的 ， 代 码 必须 
严格 遵守 语法 要 求 进行 书写 ， 任 何不 符合 规范 的 代码 都 不 能 被 计算 机 执行 ， 哪 怕 是 程序 员 写 错 一 个 字母 ， 或 者 
少 写 一 个 结束 符 都 会 使 程序 出 错 。 

所 以 ,程序 设计 语言 的 语法 必须 得 到 必要 的 重视 。 语 法 是 PHP 语言 的 规则 ， 打 好 这 个 基础 ， 循 序 渐进 地 学 
习 ， 实 际 运用 时 才 会 得 心 应 手 。 


mr 


趣味 指数 : 址 食 娘 三 | 


实例 034 


图 实例 说 明 


本 实例 应 用 PHP 标记 ， 通 过 echo 语句 和 phpinfo0 函 数 向 用 户 展示 PHP 的 配置 信息 ， 包 括 配 置 文 件 所 在 的 
目录 以 及 一 些 相关 扩展 库 的 版 本 、 作 者 信息 等 。 运 行 结果 如 图 2.1 所 示 。 


Streams 

Registered Stream 

Socket Transports 

Registered Stream |convert iconw,*, string rot13, string toupper string ,tolower, string,strip_tags, convert,*, consumed, zib,* 


图 2.1 PHP 配置 信息 
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力 关键 技术 
本 实例 的 关键 点 是 应 用 PHP 的 输出 语句 echo， 输 出 phpinfo0 函 数 的 返回 值 。phpinfo0 函 数 的 代码 如 下 ; 
该 因数 将 条 出 PHIP 的 配置 信息 。 

图 设计 过 程 
创建 mdex.php 文件 ， 应 用 PHP 标记 ， 通 过 echo 语句 输出 phpinfo0 函 数 的 返回 值 ， 其 代码 如 下 : 


<?php 
echo phpinfo0; /输出 PHP 配置 信息 
?> 


秘笈 心 法 

心 法 领悟 034: phpinfo0 函 数 的 具体 应 用 。 

在 实际 的 PHP 项 目 开 发 过 程 中 ， 用 户 加 载 的 任何 一 个 组 件 ， 在 phpinfo0 函 数 的 输出 页 面 中 都 会 显示 是 否 已 
经 获得 支持 ， 所 以 此 函数 的 应 用 对 初学 者 来 说 是 十 分 重要 的 。 


实例 035 


力 实例 说 明 


在 用 PHP 编写 的 网 站 中 ， 经 常 需要 获取 当前 时 间 。 例 如 用 户 在 什么 时 间 登 录 的 网 站 、 黑 客 攻 击 网 站 是 在 什 
么 时 间 等 。 本 实例 应 用 PHP 标记 ， 通 过 echo 语句 和 date0) 函 数 来 实现 获取 服务 器 时 间 ， 并 进行 打印 。 运 行 结果 
如 图 2.2 所 示 。 


要 红 旬 当 前 大 问 是 


图 2.2 系统 当前 时 间 


力 关键 技术 


本 实例 主要 通过 ed ed 其 语法 及 说 明 如 下 : 
date(string format,int ti 


参数 format 指定 日期 和 时 间 输 出 的 格式 ， 如 表 2.1 所 示 ， 参 数 timestamp 为 可 选 参数 ， 指 定时 间 戳 ， 如 果 没 
有 指定 时 间 戳 ， 则 使 用 本 地 时 间 time(。 


表 2.1 参数 format 的 格式 化 选项 
参数 说 有 明 


a 小 写 的 上 午 和 下 午 值 ， 返 回 值 为 am 或 pm 

A 大 写 的 上 午 和 下 午 值 ， 返 回 值 为 AM 或 PM 

B Swatch Internet 标准 时 间 ， 返 回 值 为 000~999 

d 月 份 中 的 第 几 天 ， 有 前 导 0 的 2 位 数字 ， 返 回 值 为 01~31 


D 星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 为 Mon~Sun 
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续 表 


参数 说 明 


月 份 ， 完 整 的 文本 格式 ， 返 回 值 为 January~December 


小 时 ，12 小 时 格式 ， 没 有 前 导 0， 返 回 值 为 1~12 


QA ln | 


小 时 ，24 小 时 格式 ， 没 有 前 导 0， 返 回 值 为 0~23 


i 有 前 导 0 的 分 钟 数 ， 返 回 值 为 00~59 


I 判断 是 否 为 夏令 时 ， 如 果 是 夏令 时 ， 返 回 值 为 1， 否 则 为 0 


月 份 中 的 第 几 天 ， 没 有 前 导 0， 返 回 值 为 1~31 


星期 数 ， 完 整 的 文本 格式 ， 返 回 值 为 Sunday~Saturday 


判断 是 否 为 半年 ， 如 果 是 冰 年 ， 返 回 值 为 1， 否则 为 0 


数字 表示 的 月 份 ， 有 前 导 0， 返 回 值 为 01~12 


3 个 字母 缩写 表示 的 月 份 ， 返 回 值 为 Jan~Dec 

数字 表示 的 月 份 ， 没 有 前 导 0， 返 回 值 为 1~12 

与 格林 威 治 时 间 相 差 的 小 时 数 ， 如 0200 

RFC 822 格式 的 日 期 ， 如 Thu.21 Dec 2000 16:01:07 +0200 

秒 数 ， 有 前 导 0， 返 回 值 为 00~59 

每 月 天 数 后 面 的 英文 后 级 ， 两 个 字符 ， 如 st、nd、rd 或 者 也 ， 可 以 和 j 一 起 使 用 
指定 月 份 所 应 有 的 天 数 

本 机 所 在 的 时 区 
从 UNIX 纪元 〈January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 

星期 中 的 第 几 天 ， 数 字 表示 ， 返 回 值 为 0~6 

ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 

2 位 数字 表示 的 年 份 ， 如 88、08 

4 位 数字 完整 表示 的 年 份 ， 如 1998、2008 

年 份 中 的 第 几 天 ， 返 回 值 为 0-366 

时 差 偏 移 量 的 秒 数 。UTC 西边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 ， 返 回 值 为 
一 43200-43200 


ool: lz |8 Ic |~ I~: 
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力 设计 过 程 


创建 index.php 文件 ， 通 过 echo 语句 输出 date0 函 数 的 返回 值 ， 其 代码 如 下 : 
< 


echo date('Y-m-s H:i:s); /| 输 出 当前 时 间 
> 
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心 法 领悟 035， 对 系统 时 间 的 设置 。 
看 了 上 面 的 实例 ， 读 者 也 许 会 感到 奇怪 ， 为 什么 系统 当前 的 时 间 比 正常 的 时 间 少 了 8 个 小 时 ? 原因 是 系统 


输出 的 当前 时 间 是 系统 默认 的 格林 威 治 时 间 ， 而 不 是 我 们 所 使 用 的 东 八 区 的 北京 时 间 。 


想 要 更 改 为 东 八 区 的 时 间 ， 有 两 种 方法 : 
(1) 修改 php.ini 文件 中 的 设置 ， 找 到 [date] 下 的 “;date.timezone = ”选项 ， 将 该 项 修改 为 “date.timezone 


=Asia/Hong Kong”， 然 后 重启 Apache 服务 器 。 
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(2) 在 程序 中 ， 通 过 在 使 用 日 期 格式 之 前 添加 “date_default_timezone _set(timezone);” 函 数 来 完成 对 时 区 
的 设置 。 参数 timezone 为 PHP 可 识别 的 时 区 名 称 , 如 果 PHP 无 法 识别 时 区 名 称 , 则 系统 采用 UTC 时 区 。 在 PHP 
手册 中 提供 了 各 时 区 的 名 称 列表 ， 其 中 北京 时 间 可 以 设置 时 区 为 PRC (中华 人民 共 和 国 ) 、Asia/Chongqing( 重 
庆 ) 、Asia/Shanghai (上 海 ) 、Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 间 是 等 效 的 。 


上 加 说 明 : 系统 默认 的 格林 威 治标 准时 间 (Greenwich Mean Time，GMT) 与 北京 时 间 相差 8 个 小 时 ， 在 国际 无 
线 电 通信 和 领域， 使 用 一 个 统一 的 时 间 ， 称 为 通用 协调 时 间 (Universal Time Coordinated，UTC) 。UTC 
与 格林 威 治标 准时 间 相同 。 
设置 完成 后 ， 时 间 显 示 如 图 2.3 所 示 。 


实例 036 高 级 | 


趣味 指数 : 容 但 全 伍 : 
实例 说 明 


很 多 时 候 用 户 需要 编写 包含 文件 路 径 及 文件 名 称 的 代码 ， 如 果 通 过 目录 查找 ， 未 免 有 些 麻 烦 。 这 时 用 户 可 
以 使 用 _FILE_ 预 定义 函数 。 本 实例 通过 ”FILE_ 预 定义 常量 获取 目标 文件 的 路 径 及 文件 名 称 并 在 网 页 上 进行 
打印 ， 运 行 结果 如 图 2.4 所 示 。 


C\AppServ\w MRONOaGinderphn 


2.4 输出 当前 文件 路 径 和 名 称 


力 关键 技术 


系统 预定 义 常量 和 用 户 自 定义 常量 在 使 用 上 没有 差别 。 大 多 数 预定 义 常 量 的 执行 结果 都 是 服务 器 的 相关 信 
息 (版 本 号 、 路 径 、 错 误 参 数 等 ) ， 所 以 程序 员 很 少将 此 函数 用 于 网 站 前 台 的 开发 ， 因 为 如 果 被 别有用心 的 人 
知道 了 这 些 信息 ， 会 严重 威胁 服务 器 的 安全 。 使 用 此 函数 的 语法 说 明 如 下 : 

__FILE _ 预 定义 常量 : 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 自 PHP 4.0.2 
起 ，_FILE ”总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 路 径 。 


图 设计 过 程 
创建 index.php 文件 ， 通 过 echo 语句 输出 _FILE_ 预 定义 常量 ， 其 代码 如 下 : 
<Iphp 


echo_ FILE :; /获取 文件 的 完整 路 径 
2> 


国 秘笈 心 法 


心 法 领悟 036: 预定 义 常量 的 说 明 。 
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PHP 中 可 以 使 用 预定 义 常量 获取 PHP 中 的 信息 ， 常 用 的 预定 义 常量 如 表 2.2 所 示 。 
表 2.2 ”PHP 的 预定 义 常量 


常 量 名 功 能 
FILE 默认 常量 ，PHP 程序 文件 名 
LINE 默认 常量 ，PHP 程序 行 数 
PHP VERSION 内 建 常量 ，PHP 程序 的 版 本 ， 如 3.0.8_dev 
PHP OS 内 建 常量 ， 执 行 PHP 解析 器 的 操作 系统 名 称 ， 如 Windows 
TRUE 该 常量 是 一 个 真 值 (TRUE) 
FALSE 该 常量 是 一 个 假 值 (FALSE) 
NULL 一 个 NULL 值 
E ERROR 该 常量 指 到 最 近 的 错误 处 
E WARNING 该 常量 指 到 最 近 的 警告 处 
E PARSE 该 常量 指 到 解析 语法 有 潜在 问题 处 
E NOTICE 该 常量 指 到 不 寻常 但 不 一 定 是 错误 处 


< 注意 :FILE 和 _ LINE 中 的 “_ ”是 两 条 下 划 线 ， 而 不 是 一 条 “_”。 表 中 以 上 开头 的 预定 义 常量 是 
PHP 的 错误 调试 部 分 。 如 果 想 详细 了 解 ， 请 参考 error reporting(0) 函 数 。 


高 级 | 
实例 037 起 味 指数 : 友良 志雄 ， 
实例 说 明 


输出 或 定义 字符 串 时 高 不 开 单 引号 和 双 引 号 的 修饰 ,表面 上 看 它们 似乎 没有 什么 不 同 ,实际 上 是 有 区 别 的 。 
本 实例 应 用 单 引号 与 双 引号 操作 符 来 说 明 如 何 区 分 单 引 号 和 双 引 号 ， 运 行 结果 如 图 2.5 所 示 。 


输出 字符 串 
输出 字符 串 $a 
2.5 区 分 单 引号 和 双 引 号 


力 关键 技术 


本 实例 的 关键 点 是 输出 单 引号 和 双 引 号 修饰 的 字符 串 以 显示 其 区 别 。 
使 用 双 引 号 与 单 引号 最 大 的 区 别 是 ， 双 引号 中 所 包含 的 变量 会 自动 被 替换 成 实际 数值 ， 而 在 单 引号 中 包含 
的 变量 则 按 普通 字符 串 输出 。 


图 设计 过 程 


创建 index.php 文件 ， 通 过 echo 语句 输出 用 单 、 双 引号 修饰 的 字符 串 ， 其 代码 如 下 : 
<?php 

es 

ccho 答 出 字符 串 Sa'; 


> 
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心 法 领悟 037: 转 义 字符 。 
通过 双 引 号 定义 字符 串 ， 可 以 支持 很 多 的 转 义 字符 。 如 表 2.3 所 示 为 双 引号 支持 的 转 义 字符 。 


表 2.3 双 引 号 支持 的 转 义 字符 


转 义 字符 含 义 
un 换行 (LF 或 ASCII 字符 0x0A (10) ) 
Yr 回 车 (CR 或 ASCII 字符 0x0D (13) ) 
Vt 水 平 制 表 符 (HT 或 ASCI 字符 0x09 (9) ) 
\ 反 斜 杠 
'§ 美元 符号 
V 单 引号 
Ww 双 引 号 
\[0-7]{1.3} 此 正则 表达 式 序列 匹配 一 个 用 八进制 符号 表示 的 字符 ， 如 \467 
\x[0-9A-Fa-f]{1.2} 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 符 号 表示 的 字符 ， 如 wx9f 


Wn 和 \r 在 Windows 系统 中 没有 什么 区 别 ， 都 可 以 当 作 回 车 符 ， 但 在 Linux 系统 中 则 是 两 种 效果 。 在 Linux 
中 ， 表示 换 到 下 一 行 ， 却 不 会 回 到 行 首 ， 而 \ 表示 光标 会 回 到 行 首 ， 但 仍然 在 本 行 。 如 果 读 者 使 用 Linux 操 
作 系 统 ， 可 以 尝试 一 下 这 两 个 转 义 字符 的 应 用 。 


_Bg 技巧 : 在 定义 简单 的 字符 囊 时 ， 使 用 单 引号 是 比较 合适 的 处 理 方式 。 如 果 使 用 双 引 号 ，PHP 将 花费 一 些 时 
间 来 处 理 字符 串 的 转 义 和 变量 的 解析 。 因 此 ， 笔 者 建议 在 定义 字符 串 时 ， 如 果 没有 特别 的 要 求 ， 应 
该 尽量 使 用 单 引号 。 通 过 单 引 号 定义 的 字符 串 类 型 变量 按照 普通 字符 进行 输出 。 例 如 ， 通 过 单 引 号 
定义 字符 串 '$result， 那 么 将 输出 '$result， 而 不 会 输出 变量 $result 的 实际 值 。 


[ED 说 明 : (1) 在 字符 囊 中 表示 单 引号 ， 需 要 使 用 反 斜 线 “\” 进 行 转 义 。 例 如 ， 定 义 一 个 字符 囊 “Its dogged 
that does it.”， 则 需要 写 出 “It\'s dogged that does it.”。 
(2) 在 单 引 号 或 者 字符 串 结束 位 置 表 示 反 斜 线 ， 同 样 要 用 反 斜 线 进行 转 义 ， 即 用 两 个 反 斜 线 “\\” 
表示 。 例 如 ， 表 示 字 符 串 “F:\PkKhPHPWWww”， 则 要 写 出 “F:\PkKhPHP\Wwww”。 


力 实例 说 明 


JavaScript 语言 是 一 门 功能 强大 的 客户 端 脚本 语言 ， 也 是 一 门 跨 平 台 语言 。PHP 支持 使 用 JavaScript 编码 。 
本 实例 通过 PHP 5.0 新 型 字符 串 动态 输出 JavaScript 代码 ， 运 行 结果 如 图 2.6 所 示 。 


| 来自 http://1ocalhost 的 页 面 说 : 


和 欢迎 进入 PHP 编 程 世 界 t 9? ? 


图 2.6 动态 输出 JavaScript 代码 
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图 关键 技术 


PHP 5.0 新 型 字符 串 的 使 用 是 本 实例 的 关键 。PHP 5.0 这 种 新 型 的 字符 串 是 以 “<<<” 开 始 ， 后 面 紧 跟着 字 
符 串 开始 标记 ， 之 后 为 字符 串 的 内 容 ， 最 后 以 标记 加 分 号 (本 实例 以 mark 作为 结束 标记 ) 结束 。 本 函数 一 般 用 
于 对 HTML 代码 的 格式 输出 。 


力 设计 过 程 
创建 index.php 文件 ， 通 过 PHP 5.0 新 型 字符 串 实现 实例 ， 其 代码 如 下 : 
<?php 
Sstr=<<<mark //PHP 5.0 新 型 字符 串 开始 部 分 
<script language="javascript" type="text/javascript"> //JavaScript 代码 
alert(" 欢 迎 进入 PHP 编程 世界 ! ! !"); /| 输出 提示 
</script> /| 结束 标记 
1 /新 型 字符 串 介绍 标记 
echo $str; /| 输出 字符 串 
?> 
图 秘笈 心 ; 


心 法 领悟 038: 新 型 字符 串 。 
笔者 认为 ， 新 型 字符 串 是 将 以 往 在 HTML 标签 中 嵌 套 PHP 标签 的 方式 做 了 一 次 有 效 的 逆转 。 


- ee ji 
力 实例 说 明 


在 PHP 手册 中 经 常会 看 到 一 些 返回 值 为 Boolean 的 函数 ,函数 说 明 的 讲解 可 能 是 当 符合 条 件 时 , 返回 值 
为 1， 和 否则 返回 值 为 0。 按照 正常 的 思维 ， 返 回 值 应 该 是 TRUE 和 FALSE， 因 为 它们 才 是 真正 的 Boolean 类 
型 。 其 实 这 些 都 是 类 型 转换 的 应 用 。 本 实例 介绍 PHP 中 的 数据 类 型 ， 展 示 数 据 是 如 何 进行 类 型 转换 的 ， 运 
行 结果 如 图 2.7 所 示 。 


自动 类 型 转换 : 
104 我 是 字符 串 型 数据 = 
强制 类 型 转换 ， 


图 2.7 当 数 字 遇 到 了 字符 串 


力 关键 技术 


虽然 PHP 是 弱 类 型 语言 ， 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 。 本 
实例 的 关键 点 是 运用 类 型 转换 的 特点 进行 输出 。 

(1) 系统 根据 情况 自动 转换 数据 类 型 称 为 自动 转换 。 

(2) 用 户 在 变量 名 称 前 将 想 要 转换 的 数据 类 型 写 到 括号 内 称 为 强制 转换 。 


力 设计 过 程 
(1) 创建 PHP 脚本 ， 通 过 echo 语句 输出 想 要 转换 的 变量 ， 其 代码 如 下 : 
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<?php 
$a= 10; / 整 型 数据 
和 = "我 是 字符 串 型 数据 "; /字符 串 类 型 数据 
Se=$a+t $b; 


Sf= $b+ Sa; 

echo "自动 类 型 转换 : <br>"; 

echo '10+ 我 是 字符 串 型 数据 ='.Se."<br>"; 

echo "强制 类 型 转换 。<br>"; 

echo '10+ 我 是 字符 串 型 数据 ='.(string)$e."<br>"; 
> 


(2) 将 文件 存储 于 \MR\02\039 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.7 所 示 。 
力 秘笈 心 法 


心 法 领悟 039: 类 型 转换 的 相关 说 明 。 
(1) 转换 成 整 型 。 在 将 非 整 型 数据 转换 成 整 型 时 ， 方 法 是 在 变量 前 使 用 “(integeD ”或 者 “Ginb”， 转 换 规则 如 下 。 
回 ” 浮 点 型 转换 成 整 型 ， 小 数 点 后 的 数 将 被 舍弃 ， 如 果 浮 点 数 超出 整数 取 值 范围 ， 那 么 将 无 法 得 到 有 效 的 
整 型 结果 ， 结 果 可 能 是 0 或 者 整 型 的 最 小 负数 。 
加 ”布尔 型 转换 成 整 型 TRUE 将 转换 为 1，FALSE 将 转换 为 0。 
加 ”字符 串 型 转换 为 整 型 ,将 会 对 字符 串 左 侧 的 第 1 位 进行 判断 。 如 果 第 1 位 是 数字 ， 则 从 第 1 位 开始 将 
读 取 到 的 数字 转换 成 整 型 ， 如 果 第 1 位 不 是 数字 ， 则 结果 为 0。 
(2) 转换 成 浮 点 型 。 方 法 是 在 变量 前 使 用 “(float)”， 转 换 规则 如 下 : 
回 ” 整 型 转换 为 浮 点 型 ， 其 结果 不 会 发 生变 化 。 
回 “布尔 型 转换 为 浮 点 型 ， TRUE 将 转换 为 1，FALSE 将 转换 为 0。 
回 “字符 串 型 转换 为 浮 点 型 ; 如 果 字 符 串 中 包含 小 数 点 “.” 或 科学 记 数 法 的 e 或 者 E 中 的 任何 一 个 字符 ， 
字符 串 被 当 作 浮 点 型 处 理 ， 否 则 ， 被 视 为 整 型 。 
(3) 转换 成 字符 串 型 。 方 法 是 在 变量 前 使 用 “(string)”， 和 转换 规则 如 下 。 
整 型 或 者 浮 点 型 转换 成 字符 串 型 ， 转 换 结果 为 其 数值 。 
回 “ 布尔 型 转换 为 字符 串 型 : TRUE 将 转换 为 字符 串 “1”，FALSE 将 转换 为 空 字符 串 。 
回 “ 对象 或 者 数组 型 转换 成 字符 串 型 :转换 结果 为 字符 串 对 象 或 者 字符 串 数组 。 
回 ”资源 型 转换 成 字符 串 型 : 转换 结果 为 一 个 类 似 “Resource id# ”的 字符 串 。 在 “#"” 之 后 是 PHP 在 运行 
时 分 配给 该 资源 的 标识 代号 。 
(4) 转换 成 布尔 型 。 方 法 是 在 变量 前 使 用 “(boolean)” 或 者 “(bool)”。 因 为 布尔 型 只 包含 两 个 值 ，TRUE 
和 FALSE， 所 以 其 转换 规则 包括 两 种 。 
第 一 种 ， 转 换 结 果 为 FALSE 的 情况 。 
整 型 或 者 浮 点 型 数 0。 
空 字符 串 和 字符 串 “0”。 
没有 任何 元 素 的 空 数 组 。 
没有 任何 元 素 的 对 象 。 
特殊 类 型 NULL。 
第 二 种 ， 转 换 结果 为 TRUE 的 情况 。 排 除 在 第 一 方面 说 明 的 情况 ， 其 他 转换 结果 都 为 TRUE。 
(5) 转换 成 数组 。 方 法 是 在 变量 前 使 用 “(array)”， 转 换 规则 是 : 将 非 数 组 型 转换 成 与 原 变量 数据 类 型 相 
同 的 数组 ， 数 组 中 只 有 一 个 元 素 。 
(6) 转换 成 对 象 。 方 法 是 在 变量 前 使 用 “(object)”， 转 换 规则 是 : 将 非 对 象 型 转换 成 一 个 新 的 对 象 ， 其 中 
名 为 scalar 的 成 员 变量 将 包含 原 变量 的 值 。 


因 因 办 办 加 
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实例 040 


力 实例 说 明 


大 楼 盖 得 好 不 好 主要 在 于 地 基 是 否 牢固 ， 变 量 就 是 PHP 编程 的 地 基 。 本 实例 介绍 变量 的 定义 与 应 用 ， 通 过 
echo 语句 实现 打印 “Hello World!!!” 的 小 程序 ， 运 行 结果 如 图 2.8 所 示 。 


Hello World!!! 


图 2.8 Hello World 程序 


图 关键 技术 


本 实例 的 关键 点 是 用 “$” 符 号 定义 变量 ， 通 过 echo 语句 输出 变量 。PHP 中 的 变量 使 用 “$” 加 变量 名 来 表 
示 ， 变 量 名 是 区 分 大 小 写 的 。 使 用 变量 时 ， 只 需 对 变量 直接 赋值 即 可 。 变 量 赋值 ， 是 指 给 变量 一 个 具体 的 数据 
值 ， 对 于 字符 串 和 数字 类 型 的 变量 ， 可 以 通过 “=” 来 实现 ， 其 格式 如 下 

Sname = value; 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 定 义 字符 串 变量 值 为 “Hello World!!!”， 通 过 echo 语句 输出 定义 的 变量 ， 其 代 


码 如 下 : 
<?php 
$str = "Hello World!!!"; // 定 义 变量 
echo $str; /输出 变量 
?> 


(2) 将 该 文件 存储 于 \MR\02\040 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.8 所 示 。 
秘笈 心 法 
心 法 领悟 040: 变量 的 作用 域 。 
变量 有 其 自己 的 作用 域 ， 不 同 的 作用 域 有 不 同 的 作用 范围 ， 就 像 清华 大 学 学 生 的 学 生 证 不 能 在 北京 大 学 的 


图 书馆 借阅 图 书 一 样 。 
变量 按 其 作用 域 可 以 分 为 全 局 变量 、 局 部 变量 和 静态 变量 ， 变 量 作用 域 的 说 明 如 表 2.4 所 示 。 


表 2.4 变量 作用 域 的 说 明 


即 被 定义 在 所 有 函数 以 外 的 变量 ， 其 作用 域 是 整个 PHP 文件 ， 但 是 在 用 户 自 定义 函数 内 部 是 不 可 用 的 。 
全 局 变量 《| 想 在 用 户 自 定义 函数 内 部 使 用 全 局 变量 , 要 使 用 global 关键 字 声明 , 或 者 通过 使 用 全 局 数组 $globals 进行 
访问 


局 部 变量 | 即 在 函数 的 内 部 定义 的 变量 ， 这 些 变量 只 限于 在 函数 内 部 使 用 ， 不 能 在 函数 外 部 使 用 


能 够 在 函数 调用 结束 后 保留 变量 值 ， 当 再 次 回 到 其 作用 域 时 ， 又 可 以 继续 使 用 原来 的 值 。 而 一 般 变 量 在 
静态 变量 《| 函数 调用 结束 后 ， 其 存储 的 数据 值 将 被 清除 ， 所 占 的 内 存 空 间 被 释放 。 使 用 静态 变量 时 ， 先 要 用 关键 字 
static 来 声明 变量 需要 把 关键 字 static 放 在 要 定义 的 变量 之 前 ) 


< 注意 : 在 函数 的 内 部 定义 的 变量 ， 其 作用 域 是 所 在 函数 。 如 果 在 函数 外 赋值 ， 将 被 认为 是 完全 不 同 的 另 一 
个 变量 。 在 退出 声明 变量 的 函数 时 ， 该 变量 及 相应 的 值 就 会 被 撤销 。 
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力 实例 说 明 


PHP 编程 语言 中 预定 义 了 很 多 有 用 的 变量 ， 这 些 变量 往往 起 着 非常 重要 的 作用 。 本 实例 讲解 预定 义 变量 
$_ENV 的 相关 知识 ， Die ainda 运行 结果 如 图 2.9 所 示 。 


NO [NUMBER OF_PROCESSORS. 
\system32;C: \NINDOWS; C: \h S\Systen32\WNben 
BE . CRD; . VBS; . VBE; . JS/ | -WSFS NSH 
=> x86u[PRDCESSOR_IDENTIF x86 Eanily 15 
ntel [PROCESSORALEVEL] 
[ProgranFi 1 3) =>C: \ 
- RDORS\TENE 


and 
Settings\LocAalSetvi windir] => C: AWINDONS [APp _PID] => 292 ) 


图 2.9 预定 义 变量 的 应 用 


力 关键 技术 


PHP 提供 的 预定 义 变量 有 很 多 是 非常 实用 的 ， 通 过 这 些 预定 义 变量 可 以 获取 到 用 户 会 话 、 用 户 操作 系统 的 
环境 和 本 地 操作 系统 的 环境 等 信息 ， 其 中 $_ENV 是 执行 环境 提交 至 脚本 的 变量 。 


看 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 通 过 print r 语句 输出 系统 预定 义 变量 ， 其 代码 如 下 : 

EE print x($_ENV); // 打 印 系统 的 环境 变量 

(2) 将 该 文件 存储 于 \MR\02\041 文件 夹 下 ， 命 名 为 index.php， 运 行 结果 如 图 2.9 所 示 。 
图 秘笈 心 ; 


心 法 领悟 041: 重要 的 系统 预定 义 变量 。 
系统 的 预定 义 变量 是 比较 常用 的 技术 ， 读 者 必须 牢记 ， 尤 其 是 S_ FILES、$_POST、$_GET 和 $_SESSION。 


高 级 


实例 042 趣味 指数 : 但 食 三 食 


力 实例 说 明 


变量 包括 预定 义 变量 、 可 变 变量 等 ， 预 定义 变量 在 实例 041 中 已 经 做 了 简要 介绍 ， 本 实例 通过 可 变 变 量 实 
现 输出 指定 字符 串 ， 运 行 结 果 如 图 2.10 所 示 。 


项 ERHP ， 
图 2.10 使 用 可 变 变 量 输出 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


图 关键 技术 


可 变 变量 是 一 种 独特 的 变量 ， 它 允许 动态 改变 一 个 变量 名 称 ， 其 工作 原理 是 该 变量 的 名 称 由 另外 一 个 变量 
的 值 来 确定 。 实 现 过 程 是 在 变量 前 多 加 一 个 “S$” 符号 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 一 个 字符 串 变 量 ， 然 后 在 第 1 个 字符 串 变 量 的 值 前 加 一 个 “$” 作 为 第 


2 个 变量 的 变量 名 ， 最 后 通过 echo 语句 输出 可 变 变量 ， 其 代码 如 下 : 
php 


$str name ="str_ name 1"; /定义 变量 
S$str name_ 1 = "TILike PHP!"; // 定 义 可 变 变 量 
echo $$str name; /输出 可 变 变量 
?> 
(2) 将 该 文件 存储 于 \MR\02\042 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.10 所 示 。 


心 法 领悟 042: 可 变 变 量 。 
可 变 变 量 即 是 将 两 个 变量 的 值 使 用 一 个 变量 命名 进行 操作 , 但 是 要 注意 被 引用 的 变量 名 前 要 再 加 上 一 个 “$” 
符号 。 


高 级 | 


实例 043 趣味 指数 : 请 食 傅 良 | 


力 实例 说 明 


在 定义 长 字符 串 变 量 时 ， 字 符 串 本 身 往往 包含 一 些 特殊 字符 。 例 如 ， 字 符 串 本 身 包含 双 引 号 (") ， 这 时 就 
需要 使 用 转 义 字符 对 特殊 字符 进行 转 义 。 本 实例 通过 转 义 字符 “\” 转 义 经 特殊 字符 双 引号 〈") 包含 的 字符 串 ， 
运行 结果 如 图 2.11 所 示 。 


“FHP 是 一 门 Web 开 发 最 火 的 编程 语言 。 
图 2.11 使 用 转 义 字符 输出 特殊 字符 


图 关键 技术 


本 实例 的 关键 点 是 转 义 字符 “\” 的 使 用 ， 它 除了 可 以 做 转 义 字符 外 ， 还 有 一 些 其 他 功能 ， 即 可 以 将 一 些 不 
可 打印 的 字符 显示 出 来 ， 如 a、W\b、\e、Yf、wm、\r 和 \t 等 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 通 过 echo 语句 输出 经 转 义 字符 转 义 的 特殊 字符 ， 其 代码 如 下 : 

<?php 


echo "\"PHP 是 一 门 Web 开发 最 火 的 编程 语言 "": /输出 转 义 字符 转 义 的 字符 串 
?> 


(2) 将 该 文件 存储 于 \MR\02\043 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.11 所 示 。 
力 秘笈 心 法 
心 法 领悟 043: 转 义 字符 的 功能 。 
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转 义 字符 的 功能 只 有 一 个 ， 就 是 将 特殊 字符 转 义 成 普通 字符 。 
力 实例 说 明 


常量 是 PHP 编程 基础 的 重要 组 成 部 分 ， 其 作用 是 定义 一 个 不 会 改变 的 值 。 本 实例 通过 计算 圆 的 面积 向 用 户 
说 明 常 量 是 如 何 定义 和 使 用 的 ， 运 行 结 果 如 图 2.12 所 示 。 


半径 为 10 个 单位 的 圆 的 15926 


图 2.12 使 用 常量 指定 PI 的 值 计算 圆 的 面积 


力 关键 技术 


PHP 中 通常 使 用 define0 函 数 来 定义 常量 ; 使 用 constant0 函 数 动态 获取 常量 值 ; 使 用 defined() 函 数 判断 一 个 
常量 是 否 已 经 定义 ， 使 用 get_defined_constants() 函 数 获取 所 有 当前 已 经 定义 的 常量 。 其 中 ，define() 函 数 的 语法 


i 

参数 说 明 : 

string name: 必 选 参数 ， 常 量 名 称 ， 即 标识 符 。 

mixed value: 必 选 参数 ， 常 量 的 值 。 

bool case_insensitive: 可 选 参数 ， 指 定 大 小 写 是 否 敏 感 。 设 定 为 TRUE， 表 示 不 敏感 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 通 过 define0 函 数 定 义 常量 ,将 数值 “3.1415926” 赋 给 常量 PI，， 然 后 定义 
数值 型 变量 ， 将 圆 的 半径 设 定 为 10 个 单位 。 最 后 通过 echo 语句 输出 圆 面积 ， 其 代码 如 下 : 

<php 


define("PI",3.1415926); /定义 常量 
$r=10; /定义 圆 半径 
echo "半径 为 10 个 单位 的 圆 的 面积 ".PI*($r*$r); /定义 圆 面积 
?> 
(2) 将 该 文件 存储 于 \MR\02\044 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.12 所 示 。 
图 秘笈 心 法 


心 法 领悟 044: 使 用 define() 函 数 定义 常量 的 注意 事项 。 
使 用 defineO 函 数 定义 的 常量 一 旦 定义 就 不 能 改变 或 者 取消 。 


22 运算 符 
运算 符 是 用 来 对 变量 、 常 量 或 数据 进行 计算 的 符号 ， 是 对 一 个 值 或 一 组 值 执行 一 个 指定 的 操作 。PHP 的 运 


算 符 包括 字符 串 运算 符 、 算 术 运 算 符 、 赋 值 运算 符 、 递 增 或 递减 运算 符 、 位 运算 符 、 逮 辑 运算 符 、 比 较 运算 符 
和 条 件 运算 符 。 
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实例 045 


力 实例 说 明 


运算 符 是 表达 式 的 组 成 部 分 ， 没 有 运算 符 的 表达 式 是 不 存在 的 。 本 实例 通过 使 用 算术 运算 符 设置 数字 的 加 
密 / 解 密 算法 ， 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 


8 数字 令 : |1081 
人 1084, 1415926 解密 口令 1081 | 


图 2.13 口令 加 密 图 2.14 口令 解密 


力 关键 技术 


本 实例 的 关键 点 是 将 数字 进行 算术 运算 进而 得 到 加 密 /解密 结果 。 算 术 运 算 (Arithmetic Operators) 符号 是 
处 理 四 则 运算 的 符号 ， 在 数字 处 理 中 应 用 得 最 多 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 PI。 然 后 编写 自 定义 函数 ， 在 自 
定义 函数 方法 体内 定义 加 密 或 解密 算法 。 最 后 ， 当 表单 提交 后 ， 调 用 对 应 的 加 密 或 解密 算法 ， 并 输出 结果 ， 其 
代码 如 下 : 
<?php 
echo "<form action=" method='post>"; // 输 出 表单 
echo "数字 口令 : <input name='text type='text>"; 


echo "<input type='submit name='sub' valuc= 确 定 >"; 
echo "</form>"; 


define("PI",3.1415926); /定义 常量 
funetion Encrypt($str){ // 自 定义 加 密 算法 
return $str = $str + PI; // 将 口令 与 常量 相 加 
} 
function Decrypt(Sstr){ // 自 定义 解密 算法 
retum $str = $str - PI; // 将 加 密 后 口令 与 常量 相 减 
} 
if($_POST[sub){ // 通 过 POST 方式 传 参 
echo "加 密 口 令 &nbsp;&nbsp;".Encrypt($_POST[text])."<br>"; // 取 得 加 密 后 的 结果 
$_SESSION[pwd] = Encrypt($_POST[text]): // 保 存在 SESSION 中 
<a href='index.php?pwd=1 人 > 解密 口令 </a> // 超 链接 
<?php 
iflisset($_GET[pwd]){ // 判 断 地 址 栏 中 是 否 存在 pwd 
echo "解密 口令 &nbsp:&nbsp:" Decrypt($_SESSION[pwd]): /口令 解密 


?> 


(2) 将 该 文件 存储 于 \MR\02\045 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 
国 秘笈 心 ; 


心 法 领悟 045: 运算 符 的 优先 级 。 
本 实例 并 没有 联合 应 用 多 种 运算 符 ， 当 联合 应 用 时 要 注意 运算 符 优先 级 的 问题 。 所 谓 的 优先 级 就 是 先进 行 
哪 种 运算 再 进行 哪 种 运算 符 的 运算 。 为 了 方便 ， 笔 者 将 运算 符 的 优先 级 进行 归 类 ， 如 表 2.5 所 示 。 
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表 2.5 运算 符 的 优先 级 


优先 级 别 运 算 符 

1 ++， 一 

于 +， 一 〈 正 、 负 号 运算 符 ) ，!，~ 
3 #，/，9% 

4 

本 

6 

7 

8 

9 


实例 046 


力 实例 说 明 


在 一 些 程序 中 ， 经 常 需要 将 两 个 时 间 进 行 比较 ， 但 是 由 于 时 间 是 由 年 、 月 、 日 、 时 、 分 、 秒 组 成 的 ， 比 较 
起 来 很 不 方便 ， 这 时 可 以 把 时 间 转 换 成 时 间 惟 来 进行 比较 。 本 实例 通过 date0、strtotime0 和 ceil0 函 数 实现 比较 
两 个 时 间 戳 的 大 小 ， 运 行 结 果 如 图 2.15 所 示 。 
1421739525 输出 日 期 201 


1399219200 输出 日 


距 2014 年 5 月 5 日 已 过 去 . 


图 2.15 ”比较 两 个 时 间 戳 的 大 小 


图 关键 技术 


本 实例 主要 是 通过 利用 strtotime0 函 数 将 时 间 转 换 为 UNIX 时 间 戳 ， 再 进行 相关 取 整 运算 而 实现 的 ， 其 中 涉 
及 的 相关 函数 语法 如 下 : 

(1) strtotime() 函 数 。 该 函数 预期 接受 一 个 包含 英文 日 期 格式 的 字符 串 ， 并 尝试 将 其 解析 为 UNIX 时 间 戳 : 

int strtotime( string time [, int now]); 

strtotime() 函 数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如 果 参 数 time 的 格 
式 是 相对 时 间 ， 其 对 应 的 时 间 由 参数 now 来 提供 ， 若 没有 提供 参数 now， 则 其 对 应 的 时 间 为 当前 时 间 。 如 果 解 
析 失 败 ， 则 返回 FALSE。 在 PHP 5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 
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(2) ceil0 函 数 。 该 函数 返回 不 小 于 value 的 下 一 个 整数 : 


float ceil ( float value); 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 对 PHP 语言 中 的 时 区 进行 设置 ， 将 时 区 更 改 为 中 国 上 海 时 区 。 然 后 ， 通 过 
strtotime0 〇 函数 获取 当前 时 间 的 UNIX 时 间 戳 ， 并 与 指定 的 时 间 戳 进行 算术 和 运算。 最后， 将 时 间 戳 运算 结果 转换 
为 天 数 ， 并 通过 ceil0 函 数 进 行 取 整 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 

<?php 


date_default_timezone set("Asia/ShangHai"): // 将 格林 威 治 时 间 设 置 为 本 地 时 间 
$a = strtotime("now"); // 取 得 当前 时 间 截 
$b = strtotime("05 May 2014"); /取得 2014 年 5 月 5 日 的 时 间 戳 
echo Sa 
echo "输出 日 期 ".date("Y-m-d H:i:s",$a)."<br><br>"; // 取 得 以 $a 为 时 间 点 的 时 间 
echo $b."\n"; 
echo "输出 日 期 ".date("Y-m-d H:i:s",$b)."<br><br>"; // 取 得 以 $b 为 时 间 点 的 时 间 
$c = ceil(($a - $b)/(3600*24)): /计算 相差 天 数 
echo " 距 2014 年 5 月 5 日 已 过 去 "$c" 天 "; 
> 
(2) 将 该 文件 存储 于 \MR\02\046 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.15 所 示 。 
秘笈 心 法 


心 法 领悟 046: 时 间 戳 的 相关 说 明 。 

有 效 的 时 间 戳 的 范围 通常 从 Fri, 13 Dec 1901 20:45:54 GMT 到 Tue, 19 Jan 2038 03:14:07 GMT (对 应 于 32 位 
有 符号 整数 的 最 小 值 和 最 大 值 ) 。 不 是 所 有 的 平台 都 支持 负 的 时 间 戳 ,因此 日 期 范围 就 被 限制 为 不 能 早 于 UNIX 
纪元 。 这 意味 着 在 1970 年 1 月 1 日 之 前 的 日 期 将 不 能 用 在 Windows、 一 些 Linux 版 本 以 及 几 个 其 他 的 操作 系 
统 中 。 


<4 拉 注意 : 在 UNIX 系统 中 ， 日 期 与 时 间 表 示 为 自 1970 年 1 月 1 日 零点 起 到 当前 时 刻 的 秒 数 ， 这 种 时 间 称 为 
UNIX 时 间 蕉 ， 用 32 位 二 进 制 表示 。 其 中 ，1970 年 1 月 1 日 零点 称 为 UNIX 世纪 元 。UNIX 时 间 戳 
提供 了 一 种 统一 、 简 洁 的 时 间 表示 方式 ， 在 不 同 的 操作 系统 中 均 受 到 支持 ， 同 一 时 间 在 UNIX 和 
Windows 中 均 以 相同 的 UNIX 时 间 戳 表示 ， 所 以 不 需要 在 不 同 的 系统 中 进行 转换 。 同 时 ，UNIX 时 
间 稚 是 一 个 时 间 差 ， 与 时 区 没有 关系 ， 无 论 当前 PHP 中 使 用 的 是 何 种 时 区 ， 其 UNIX 时 间 惟 是 唯 


一 的 。 
六 高 级 | 
实例 047 趣味 指数 : ooholodl| 


力 实例 说 明 


条 件 运算 符 用 于 执行 或 真 或 假 运算 。 本 实例 演示 如 何 用 三 元 运算 符 判断 数字 的 奇偶 性 , 运行 结果 如 图 2.16 
所 示 。 


0 是 偶数 1 是 奇数 3 是 奇数 
5 是 奇数 6 是 偶数 8 是 偶数 9 是 奇数 


2.16 用 三 元 运算 符 判断 数字 的 奇偶 性 


第 2 章 PHP 基础 


图 关键 技术 


本 实例 使 用 三 元 运算 符 判断 数字 的 奇偶 性 ， 并 且 在 判断 数字 奇偶 性 时 使 用 了 求 余 运算 符 。 当 期 望 数 字 与 数 
字 2 做 除法 运算 时 ， 如 果 存 在 余数 即 不 能 被 2 整除 ， 为 奇数 ， 否 则 为 偶数 。 三 元 运算 符 的 语法 如 下 : 


(expr) ? {statementl;} : {statement2;} 


三 元 运算 符 与 和 f..else... 语 句 实现 的 功能 完全 相同 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 通 过 for 循环 语句 循环 输出 0~9 的 10 个 数字 。 然 后 ， 将 得 到 的 10 个 数字 


分 别 与 2 做 求 余 运算 并 将 运算 结果 作为 三 元 运算 的 条 件 进 行 判断 。 最 后 ， 将 判断 的 结果 利用 echo 语句 输出 ， 其 
代码 如 下 : 


< 
/做 小 于 10 的 循环 
for($a = 0:Sa < 10:Sat++jf 
// 用 三 元 运算 输出 ， 如 果 没 有 余数 则 是 偶数 ， 否 则 为 奇数 
echo $a%2==0? $a." 是 偶数 "."\n" :$a." 是 奇数 "."n"; 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\047 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.16 所 示 。 
力 秘笈 心 法 


心 法 领悟 047: 用 让 ..else.… 语 句 实现 实例 。 
三 元 运算 等 同 于 if...else... 语 句 ， 下 面 通过 if...else... 语 句 实现 本 实例 ， 其 语法 如 下 : 


<?php 
/做 小 于 10 的 循环 
for($a = 0:$a < 10:$at+){ 
/用 站..else… 语 句 实现 
Sb=0; 


if($a% 2 —0){ 
// 设 定 条 件 ， 让 $a 与 2 做 求 余 运算 
echo "Sa" 是 偶数 
jakef 
ccho "San 是 奇数 ; 
} 
} 
?> 
级 | 
实例 048 高 | 
实例 起 叶 指 娄 ， blll 


力 实例 说 明 


逻辑 运算 符 往往 作为 ff 等 语句 的 条 件 出 现 。 逻 辑 运 算 符 有 很 多 种 而 且 功 能 各 不 相同 。 本 实例 介绍 逻辑 运算 
符 的 语法 等 相关 知识 , 并 通过 逻辑 运算 符 来 演示 用 户 是 否 具 有 后 台 管理 权限 , 运 各 外 直 系 闻 轩 2.17 和 图 2.18 所 示 。 


图 2.17 具有 后 台 管 理 权限 图 2.18 不 具有 后 台 管理 权限 
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图 关键 技术 


本 实例 主要 是 通过 逻辑 运算 符 && (逻辑 与 ) ， 将 从 表单 中 利用 POST 方法 取得 的 由 文本 框 输入 的 用 户 名 和 
密码 联系 起 来 。 用 户 名 和 密码 必须 同时 为 真 ， 让 语句 的 结果 才 会 为 真 ， 反 之 为 假 。 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 form 表单 ， 将 表单 中 的 method 方法 定义 为 POST。 然后 ， 当 单 击 按 
钮 时 ， 将 POST 方法 接收 的 用 户 名 和 密码 进行 逻辑 与 运算 。 当 站 语 句 的 结果 为 TRUE 时 ， 输 出 “您 具有 管理 员 
权限 ”的 提示 ， 和 否则 输出 “您 非 权 限 用 户 ” 的 提示 ， 其 代码 如 下 : 

Ce echo "<form action="method=!post>"; /| 输出 表单 

echo "用 户 名 : <input type='text name='text><br>"; 


echo " 密 &nbsp:&nbsp: 码 : <input type= password name=pwd>"; 
echo "<input type='submit name='sub' value= 确 定 >"; 


echo "</form>"; 
ifS_POST[sub]){ /通过 POST 方式 提交 
if($_POST[text] 一 "mr" && $_POST[pwd] 一 "mrsoft"){ /验证 用 户 名 和 密码 
echo "<script>alert( 您 具有 管理 员 权限 ):</script>": /符合 条 件 输出 提示 
jelsef 
echo "<script>alert( 您 非 权 限 用 户 ):</script>"; // 不 符合 条 件 输出 提示 


} 
} 


> 


(2) 将 该 文件 存储 于 \MR\02\048 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.17 和 图 2.18 所 示 。 
国 秘笈 心 ; 
心 法 领悟 048: 使 用 优先 级 的 小 技巧 。 


如 果 在 涉及 运算 符 的 优先 级 时 不 想 总 查找 优先 级 表 而 本 身 又 记忆 不 清 的 话 ， 建 议 使 用 小 括号 把 想 要 先 运算 
的 表达 式 括 起 来 ， 这 样 问题 就 迎刃而解 了 。 


实例 049 


力 实例 说 明 


在 应 用 字符 串 时 往往 需要 将 两 个 字符 串 进行 连接 ， 这 时 可 以 使 用 字符 串 运算 符 。 本 实例 使 用 字符 串 运算 符 
打印 随机 组 合生 日 祝福 语 ， 运 行 结果 如 图 2.19 所 示 。 


生日 快乐 祝 你 方 事 刀 意 | 


2.19 打印 随机 组 合生 日 祝福 语 


图 关键 技术 


字符 串 可 以 用 “.” (点 ) 字符 串 连接 符 连 接 ， 该 连接 符 可 以 把 两 个 或 两 个 以 上 字符 串 连 接 成 一 个 新 的 字符 
串 。 字 符 串 的 连接 有 两 种 形式 ， 第 一 种 是 连接 运算 符 “.”; 第 二 种 是 连接 赋值 运算 符 “.=”。 在 实际 的 程序 开 
发 中 ， 这 两 种 连接 方式 都 很 常用 。 


力 设计 过 程 
创建 ndex php 文件 ， 首 先 ， 定 义 两 个 数组 ， 将 字符 串 信息 保存 在 数组 中 。 然 后 ， 利 用 rand0 函 数 随机 取得 
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数组 中 的 两 条 信息 并 保存 在 变量 中 。 最 后 ， 通 过 echo 语句 输出 用 连接 运算 符 连 接 的 变量 ， 其 代码 如 下 : 
<2pl 


hp 
$arr =array(" 生 日 快乐 "," 今 天 是 你 的 出 生日 "." 同 学 们 为 你 许愿 "); /定义 数组 
$array = array(" 视 你 万 事 如 意 "," 祝 你 生日 快乐 "." 祝 你 福 如 东海 长 流水 寿 比 南山 不 老 松 "); 。 // 定 义 数 组 
Srand = rand(0.2); /定义 随机 数 
echo $arr[Srand].Sarray[$rand]; /输出 字符 串 
?> 
图 秘笈 心 法 


心 法 领悟 049: “+” 号 的 相关 说 明 。 
使 用 过 C 或 Java 语言 的 读者 应 该 注意 ， 这 里 的 “+” 号 ， 只 做 算术 运算 符 使 用 ， 而 不 能 做 字符 串 运 算 符 。 


高 级 | 
| 


实例 050 六 中 六 友信 信人 娘 


力 实例 说 明 
在 PHP 语言 中 ， 为 了 提升 编程 效率 设置 了 一 些 自 增 自 减 运算 符 ， 这 些 运算 符 在 循环 语句 中 得 到 广泛 应 用 。 
本 实例 简要 介绍 自 增 自 减 运算 符 ， 并 通过 自 增 自 减 运算 符 修饰 的 变量 来 演示 其 应 用 ， 运 行 结果 如 图 2.20 所 示 。 


2000 2004% 2003 20160 202( 
图 2.20 打印 2000~2020 年 间 的 所 有 半年 


图 关键 技术 


递增 或 递减 运算 符 有 两 种 使 用 方法 ， 一 种 是 先 将 变量 增加 或 减少 1 后 再 将 值 赋 给 原 变量 ， 称 为 前 置 递增 或 
递减 运算 符 〈 也 称 前 置 自 增 自 减 运算 符 ) ; 另 一 种 是 将 运算 符 放 在 变量 后 面 ， 即 先 返 回 变 量 的 当前 值 ， 然 后 变 
量 的 当前 值 增加 或 减少 1， 称 为 后 置 递 增 或 递减 运算 符 〈 也 称 后 置 自 增 自 减 运算 符 ) 。 本 实例 将 递增 或 递减 运 
算 符 应 用 到 for 循环 的 变量 中 ， 利 用 变量 的 变化 完成 期 望 次 数 的 循环 。 


图 设计 过 程 
创建 index.php 文件 ， 首 先 ， 利 用 for 循环 定义 循环 变量 ， 将 变量 的 初始 值 设置 为 2000， 最 大 值 小 于 2020， 


并 且 要 求 变量 做 自 增 运算 。 然 后 ， 设 置 循环 变量 与 4 做 求 余 运算 。 最 后 ， 把 符合 条 件 的 数值 通过 echo 语句 输出 ， 
代码 如 下 : 


<?php 
if$_ POST[sub]){ /通过 POST 接收 参数 
for($a = 2000:$a <= 2020:$at+){ // 通 过 循环 定义 循环 变量 
if($a% 4=— 0){ // 将 循环 变量 与 4 做 求 余 运算 
echo $a."&nbsp:&nbsp:": /输出 循环 变量 
} 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 050: 自 增 自 减 运算 符 。 
自 增 自 减 运算 符 在 PHP 循环 结构 中 ， 特 别 是 for 循环 结构 中 有 着 非常 重要 的 地 位 。 至 于 自 增 自 减 运算 符 前 
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置 和 后 置 的 区 别 ， 请 详 见 实例 051 。 


实例 051 


力 实例 说 明 
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前 置 运 算 符 与 后 置 运算 符 的 应 用 方向 与 实例 050 相同 ， 大 多 用 在 循环 语句 中 。 本 实例 应 用 自 增 自 减 运算 符 
来 修饰 变量 ， 通 过 显示 结果 来 说 明 前 置 运 算 符 与 后 置 运算 符 的 区 别 ， 运 行 结 果 如 图 2.21 所 示 。 


-| 后 置 加 证 算 -…- 
012345678910 
~ 前 甘 加 运算 
1234567891011 


~ 前 置 减 运 算 - 广 -二 


987654321gMC 人 


| 后 轩 需 运算 …-- 
109876543210 


图 2.21 前 置 运算 符 与 后 置 运算 符 的 区 别 


图 关键 技术 


本 实例 的 关键 点 是 自 增 自 减 运算 符 的 灵活 运用 ， 相 关 说 明 详 见 实例 050。 在 使 用 前 置 减 运算 符 时 ， 要 注意 


给 定 的 初始 值 ， 
力 设计 过 程 


否则 会 出 现 本 例 的 问题 ， 即 前 置 减 运算 输出 负数 。 


(1) 创建 PHP 脚本 文件 ， 首 先 通过 for 循环 语句 定义 循环 变量 ， 然 后 通过 echo 语句 输出 循环 变量 ， 其 代 


和 


后 置 加 运算 
for($b= 0;$b <= 10:$Sb++){ 
echo Satt." "; 


echo "<br>--- 一 -一 前 置 加 运算 -一 一 一 <br>"; 


$d=0; 
for(Sb = 0:Sb < 10; 2 
echo ++$d. 


} 
echo 人生 本 下 全 


$f=10: 
for($b = 10:$b >= 0:$b--){ 


echo "<br>----—-- 后 置 减 运算 -<br>"; 


Sg =10: 

for($b = 10:Sb >= 0:$b-){ 
echo Sg—" "; 

} 


?> 


// 自 定义 变量 并 给 定 初始 值 


// 使 用 for 循环 语句 
// 使 用 后 置 运 算 符 


// 使 用 前 置 运 算 符 


// 使 用 前 置 运 算 符 


// 使 用 后 置 运 算 符 


(2) 将 该 文件 存储 于 \MR\02\051 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.21 所 示 。 


国 秘笈 心 法 


心 法 领悟 051: 前 置 运 算 符 与 后 置 运算 符 。 
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前 置 运算 符 是 在 程序 第 一 次 运行 时 就 进行 自 增 或 自 减 运算 ， 而 后 置 运算 符 是 在 程序 运行 完 一 次 之 后 再 进行 
自 增 或 自 减 运算 。 


实例 052 字 进 行 加 密 和 解密 高 级 


趣味 指数 : 伍 食 食 伍 1 


有 on eas sds on ns on eo ron dror nor erredr endo edad dor te0 rrr J 


力 实例 说 明 
位 运算 符 也 是 PHP 运算 符 中 不 可 或 缺 的 一 种 。 本 实例 通过 位 运算 符 实现 对 数字 进行 加 密 和 和 解密， 运行 结果 


如 图 2.22 和 图 2.23 所 示 。 


数字 口令 绰 111 [ 确定 | i 一 
证 泌 解 窗口 令 111 
图 2.22 使 用 位 运算 符 对 数字 进行 加 密 图 2.23 ”使 用 位 运算 符 对 数字 进行 解密 
图 关键 技术 


位 运算 符 是 指 对 二 进 制 位 从 低 到 高 位 对 齐 后 进行 运算 ，PHP 中 的 位 运算 符 如 表 2.6 所 示 。 本 实例 中 ， 利 用 
自 定义 函数 将 文本 框 信息 与 定义 的 常量 做 指定 的 位 运算 ， 并 返回 计算 结果 ， 从 而 将 文本 框 信息 进行 加 密 或 解密 
处 理 。 


表 2.6 位 运算 符 


举例 
Sm&sn 
Sml$n 
3$m^$n 
Sm~$n 
$m<<$n 
$m>>$n 


力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 form 表单 并 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 PL。 然 后 ， 定 


义 自 定义 函数 ， 在 函数 体内 部 ， 将 文本 框 信息 与 常量 PI 做 移 位 运算 并 返回 结果 。 最 后 ， 通 过 提交 数据 和 单 击 按 
钮 实现 输出 加 密 、 解 密 算法 的 结果 ， 其 代码 如 下 : 
<2php 


/定义 表单 

echo "<form action=" method='post>": 

echo "数字 口令 : <input name='text type='text>"; 

echo "<input type='submit’ name='sub' valuc= 确 定 >"; 

echo "</form>"; 

define("PI".3.1415926): /定义 常量 

function Enerypt($str){ // 自 定义 加 密 算法 
Tetum $str = $str << PI: 

} 

function Decrypt($st){ // 自 定义 解密 算法 
Tetum $str = $str >> PT: 

1 

if($_POST[sub){ // 通 过 POST 方式 传 参 
echo "加 密 口 令 &nbsp:&nbsp:".Encrypt($_POST[text])."<br>": /输出 口令 
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$_SESSION[pwd] = Encrypt($ POST[text): // 将 口令 保存 在 SESSION 中 
> 
<a href='index.php?pwd=1> 解 密 口令 </a> // 超 链接 
<php 
iflisset($_GET[pwd]){ 1/ 判断 地 址 栏 是 否 存 在 此 参数 
echo "解密 口令 &nbsp;&nbsp;".Decrypt($_SESSION[pwd]); // 输 出 解密 结果 


} 

(2) 将 该 文件 存储 于 \MR\02\052 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.22 和 图 2.23 所 示 。 

心 法 领悟 052: 位 运算 符 的 相关 说 明 。 

位 运算 符 允 许 对 整 型 数据 中 指定 的 位 进行 置 位 。 如 果 左 右 参数 都 是 字符 串 ， 则 位 运算 符 将 操作 字符 的 
ASCII 值 。 


23 包含 语句 


引用 外 部 文件 可 以 减少 代码 的 重用 性 ， 是 PHP 编程 的 重要 技巧 。PHP 提供 了 4 个 非常 简单 有 用 的 语句 ， 它 
们 允许 重新 使 用 任何 类 型 的 代码 。 使 用 任意 一 个 语句 均 可 以 将 一 个 文件 载 入 PHP 脚本 中 ， 为 网 站 创建 统一 风格 
的 页 面 ， 从 而 更 加 轻松 地 编写 和 维护 代码 。 


实例 说 明 


当 需 要 在 文件 外 部 引入 新 文件 时 就 要 借助 include 或 require 等 包含 语句 。 本 实例 通过 require 包含 语句 实现 
代码 重用 ， 运 行 结果 如 图 2.24 所 示 。 


| 
高 级 | 
趣味 指数 : 傅 塘 请 计 


汽车 在 公路 上 行 强 , 不 一 会 后 面 来 了 -条 
ee 下 下 了 ， A 


四 2.24 提高 代码 重用 率 


图 关键 技术 


本 实例 通过 require 语句 包含 并 运行 指定 文件 。 PHP 文件 被 执行 之 前 ，PHP 解析 器 会 用 被 引用 文件 的 全 部 内 
容 蔡 换 require 语句 ， 然 后 与 require 语句 之 外 的 其 他 语句 组 成 新 的 PHP 文件 。 最 后 再 按 新 的 PHP 文件 执行 程序 
代码 ， 其 语法 如 下 : 

void require(string filename): 


和 el 
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参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 


力 设计 过 程 
(1) 创建 ne php 文件 ， 建 立 两 个 字符 串 表达 式 ， 代 码 如 下 : 
hp 


pl 
$strl =" 大 连 是 一 个 美丽 的 地 方 ， 它 三 面 环 海 ， // 声 明 两 个 字符 串 变量 

背 依 大 山 ， 就 像 一 个 乘风破浪 的 水 手 , 

就 算 再 大 的 风浪 ， 也 依然 昂首 挺 胸 不 届 不 挠 "; 

$str2 = "一 天 ， 老 杨 开 着 自己 的 奥拓 小 汽车 在 公路 上 行驶 ， 不 一 会 后 面 来 了 一 辆 大 奔 。 

大 奔 司 机 冲 着 老 杨 说 : “哥们 ， 开 过 大 奔 吗 ? ”然后 哦 一 下 开 走 了 ， 老 杨 很 生气 ， 心 想 

开 大 奔 就 牛 吗 ， 然 后 加 大 油门 ， 赶 上 了 大 奔 ， 大 奔 司 机 又 问 : “哥们 ， 开 过 大 奔 吗 ?” 然 后 哦 一 下 

开 走 了 ， 老 杨 再 也 排 不 上 了 。 只 能 生 着 闷气 地 向 前 开 着 ， 过 了 一 会 ， 路 边 翻 着 一 辆 大 奔 ， 司 机 被 压 在 车 下 ， 
看 见 老 杨 开 车 过 来 ， 就 带 着 哭 腔 说 : “老大 。。。 你 开 过 大 奔 吗 。。。 和 刹车 在 哪 啊 ? ”"; 

> 


(2) 创建 index.php 文件 ， 通 过 require 语句 包含 文件 inc.php， 代 码 如 下 : 


php 
require("inc. php"); 
switch($_GET[link]){ // 接 收 地 址 栏 的 值 
case "我 的 家 乡 "; // 如 果 值 等 于 “我 的 家 乡 ” 
echo Sstrl; // 输 出 字符 串 1 
break: /停止 执行 语句 
case "幽默 笑话 "; /如 果 值 等 于 “幽默 笑话 ” 
echo $str2; /输出 字符 串 2 
rs /停止 执行 语句 
> E 
力 秘笈 心 法 


心 法 领悟 053: 使 用 require 语句 的 注意 事项 。 
因为 使 用 require 语句 相当 于 将 另 一 个 源 文件 的 内 容 完全 复制 到 本 文件 中 ,所 以 一 般 将 该 语句 放 在 源 文件 的 
起 始 位 置 ， 用 于 引用 需要 使 用 的 公共 函数 和 公共 类 文件 等 。 


力 实例 说 明 


一 个 程序 可 能 要 与 数据 库 多 次 交互 ， 所 以 数据 库 连接 信息 要 单独 保存 在 某 一 文件 中 ， 这 也 是 代码 重用 的 一 
种 体现 。 本 实例 通过 include 语句 包含 数据 库 文件 ， 运 行 结果 如 图 2.25 所 示 。 


编号 ，1 姓名 : 杨 明 


高 级 | 
趣味 指数 : 友 克 克 页 ， 


编号 ，6 姓名 , 刘 员 华 ， 
图 2.25 包含 数据 库 连 接 文件 


图 关键 技术 


include 语句 与 require 语句 在 作用 上 是 完全 相同 的 ， 但 是 使 用 include 语句 引用 外 部 文件 时 ， 只 有 代码 执行 
到 该 语句 时 才 将 外 部 文件 引用 进来 并 读 取 文件 的 内 容 ， 当 所 引用 的 外 部 文件 发 生 错 误 时 ， 系 统 只 给 出 一 个 警告 ， 


PHP 开发 实例 大 全 (基础 卷 ) 
整个 PHP 文件 则 继续 向 下 执行 。include 语句 的 语法 如 下 : 


void include(string filename): 
参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 
力 设计 过 程 
(1) 创建 index.php 文件 ， 通 过 include 语句 包含 数据 库 文件 ， 并 执行 查询 操作 输出 结果 ， 其 代码 如 下 : 
让 ("inc.php"); // 包 含 数据 库 连接 文件 
$sql = "select * from tb_include"; /SQL 语句 
S$rs = mysql query($sq]); /执行 查询 操作 
while($rst = mysql fetch_array($rs)){ // 将 查询 结果 循环 输出 


echo 编号 ，'Srst[0],&nbsp:&nbsp: 姓 名 : "Srst[1]."<br>": 


?> 
人 创建 数据 库 连 接 文件 inc.php， 其 代码 如 下 : 


Re mysql_connect("localhost", "root","111"): /连接 MySQL 
mysql_select_db("db_database02",$conn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"); /设置 编码 格式 
> 

力 秘笈 心 法 


心 法 领悟 054: 使 用 include 语句 的 注意 事项 。 
include 语句 包含 一 个 不 存在 的 文件 时 会 产生 警告 。 


力 实例 说 明 
在 设计 网 站 的 过 程 中 往往 都 是 先 用 <table> 或 <div> 标 签 将 整个 网 站 进行 布局 ， 然 后 通过 include_once 等 语句 
将 各 部 分 内 容 包含 进来 。 本 实例 介绍 使 用 include_once 语句 包含 网 站 头 文件 ， 运 行 结果 如 图 2.26 所 示 。 


| 
高 级 | 
起 呆 指 数 帘 贾 页 寅 wx 


2.26 包含 网 站 头 文件 


图 关键 技术 


PHP 程序 开发 中 ， 在 使 用 include_once 语句 时 ， 应 该 明确 其 与 mclude 语句 的 区 别 。include_once 语句 会 在 
导入 文件 前 检测 该 文件 是 否 在 该 页 面 的 其 他 部 分 被 引用 过 ， 如 果 有 ， 则 不 会 重复 引用 该 文件 ， 即 程序 只 引用 一 
次 。 例 如 ， 要 导入 的 文件 中 存在 一 些 自 定义 函数 ， 如 果 在 同一 个 程序 中 重复 导入 这 个 文件 ， 在 第 二 次 导入 时 便 
会 发 生 错误 ， 因 为 PHP 不 允许 相同 名 称 的 函数 被 重复 声明 。 
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图 设计 过 程 

(1) 创建 index.php 文件 ， 通 过 include_once 语句 包含 文件 inc.php， 其 代码 如 下 : 

<table><tr><td><?php include_once("inc .php"):?></td></tr></table> // 在 table 标签 中 嵌入 PHP 包含 语句 
(2) 创建 inc.php 文件 ， 将 图 片 作为 <body> 标 签 的 背景 图 ， 其 代码 如 下 : 

<title> 包 含 头 文件 </title> 

<body background=". /image/1 jpg" style="font-size:14px; color:#000099; font-family:' 微 软 雅 黑 "> 。” // 背 景 

<img sre="image/1.jpg"> /1/ 引 入 图 片 

<body> 
(3) 运行 本 实例 ， 运 行 结果 如 图 2.26 所 示 。 

秘笈 心 法 


心 法 领悟 055: 使 用 include_once 语句 的 注意 事项 。 
include_once 语句 应 用 于 在 脚本 执行 期 间 同 一 个 文件 有 可 能 被 包含 超过 一 次 的 情况 下 , 确保 指定 文件 只 被 包 
会 一 次 ， 从 而 避免 函数 重复 定义 ， 变 量 重新 赋值 。 


起 味 指数 : 贾 机 页 页 | 


实例 056 


国 实例 说 明 
require 语句 和 include 语句 在 作用 上 没有 本 质 区 别 , 用 户 可 根据 个 人 习惯 选择 使 用 。 本 实例 通过 使 用 require 


语句 包含 网 站 尾 文件 ， 运 行 结果 如 图 2.27 所 示 。 
ss 


ant 二 区 


| 


2.27 包含 网 站 尾 文件 


力 关键 技术 
本 实例 的 关键 点 是 rerquire 语句 的 运用 。require 语句 的 详细 说 明 请 参见 实例 053。 
力 设计 过 程 
(1) 创建 index.php 文件 ， 编 写 PHP 标记 ， 通 过 require 语句 包含 文件 inc.php， 其 代码 如 下 : 
ravinephp); /包含 尾 文件 


多 
(2) 创建 nc.php 文件 , 定义 网 站 尾 文件 , 利用 <p> 标 签 将 明日 科技 公司 的 相关 信息 包含 进来 , 其 代码 如 下 : 
<table width="800" height="129" border="1" bordercolor="#CCCCCC" bordercolorlight="#CCCCCC" cellspacing="0"> 
> 
7 width="800"><div align="center"> /定义 表格 
<p> 长 春 市 明日 科技 有 限 公司 </p> 
<p> 电 话 : 0431-84978981</p> 
<p> 传 真 : 0431-84978981</p> 
<p>email:www.mrsoft.com</p> 
<ldiv><ltd> 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<ftr> 
</table> 


(3) 运行 本 实例 ， 运 行 结果 如 图 2.27 所 示 。 


心 法 领悟 056: 使 用 require 语句 的 注意 事项 。 
require 语句 包含 不 存在 的 文件 时 会 出 现 一 个 致命 错误 。 


高 级 : 
起 叶 指示: 裕 友 机 页 


实例 057 


力 实例 说 明 


- 记 估 时 糙 圩 州 ” 加 次 内 攻 湾 队 痢 ~ 
介入 ” 蝴 冯 市 隐 戎 若 雹 ”证 加 本 台 
有 ”加 妥 刘 两 炎 届 其 ” 滑 |r 州 关 种 


图 2.28 包含 网 站 主 文件 


力 关键 技术 


require_once 语句 是 require 语句 的 延伸 ， 其 功能 与 require 语句 基本 类 似 ， 不 同 的 是 在 应 用 require_once 语 
句 时 会 先 检查 要 引用 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 引用 过 , 如 果 有 , 则 不 再 重复 调用 该 文件 .例如 ， 
同时 应 用 require_once 语句 在 同一 个 页 面 中 引用 了 两 个 相同 文件 ， 那 么 在 输出 时 只 有 第 一 个 文件 被 执行 ， 第 二 
次 引用 的 文件 不 会 被 执行 。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 通 过 switch 语句 接收 地 址 栏 传递 的 参数 ， 根 据 参数 传递 的 数据 引入 通过 
Tequire_once 语句 包含 的 文件 ， 其 代码 如 下 : 


<?php 
switch($_GET[link]){ /通过 GET 方式 接收 地 址 栏 参数 
case "首页 ": 
require_once(inc.php"); /包含 文件 inc.php 
break: 
case "注册 ” 
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require_once('ine_1.php): // 包 含 文件 inc_1.php 
break: 
case "浏览 ": 
require_once(inc_ 2.php); /包含 文件 inc 2.php 
break: 
default: 
inelude(inephp): 


} 
> 


(2) 运行 本 实例 ， 运 行 结果 如 图 2.28 所 示 。 


心 法 领悟 057: 使 用 require_once 语句 的 注意 事项 。 
require_once 语句 与 require 语句 一 样 ， 当 包含 不 存在 的 文件 时 ， 会 出 现 一 个 致命 错误 。 


2.4 条 件 语句 


条 件 控制 语句 就 是 以 一 定 的 条 件 作 为 依据 ， 根 据 判 断 的 结果 确定 执行 哪 一 部 分 代码 ， 而 不 执行 与 该 部 分 代 
码 并 列 的 其 他 代码 。 

在 PHP 中， 条 件 控制 语句 可 分 为 以 下 两 种 类 型 : 

回 这 条 件 控制 语句 。 

加 ”switch...case 分 支 控制 语句 。 


图 实例 说 明 


在 PHP 应 用 中 ， 类 似 生日 提醒 等 功能 的 程序 随处 可 见 ， 主 要 是 因为 这 样 的 程序 有 一 定 的 定时 效果 。 本 实例 
通过 站 语句 和 foreach 循环 语句 实现 一 个 员工 生日 提醒 的 小 程序 ， 如 图 2.29 所 示 。 


图 2.29 员工 生日 提醒 


力 关键 技术 


本 实例 的 关键 点 是 利用 让 条 件 语句 ， 将 文本 框 中 的 日 期 与 数组 中 员工 生日 日 期 进行 比较 。 
(1) foreach 语句 


foreach 语句 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。 


foreach (array_expression as $value) statement: 


参数 array 表示 要 遍历 的 数组 ，expression 表示 键 值 ，$value 表示 键 值 的 对 应 值 ，statement 表示 语句 块 。 
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(2) 站 语句 

让 语句 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ， 否 则 跳 过 这 段 程序 。 

这 expD statement; 

参数 expr 表示 判定 条 件 ，statement 表示 语句 块 。 

(3) array0 函 数 

arrayO 函 数 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 => 运算 符 给 出 索引 。 

amay array ( [mixed ..)); 
图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 根据 数 组 的 特点 将 键 值 与 对 应 值 存储 在 数组 中 ， 然后， 利用 foreach 语句 
遍历 数组 ， 将 取得 的 value 值 与 当前 日 期 进行 比较 。 最 后 ， 将 符合 条 件 的 值 进行 输出 ， 其 代码 如 下 : 


<?php 
$a = array(" 小 杨 "=>"05 月 30 日 "," 小 王 "=>"05 月 28 日 "," 小 张 "=>"05 月 29 日 "); // 定 义 数 组 
foreach($a as $key => $value){ // 用 foreach 语句 循环 数组 
if(date("m 月 d 日 ") 一 $value){ /用 让 条 件 语句 进行 比较 
echo "&nbsp;&nbsp; 今 天 是 ".Skey." 的 生日 ": /输出 结果 
} 
} 
> 
(2) 运行 本 实例 ， 运 行 结果 如 图 2.29 所 示 。 
秘笈 心 法 


心 法 领悟 058: 使 用 foreach 语句 的 相关 说 明 。 
foreach 语句 所 操作 的 数据 是 指定 数组 的 一 个 副本 ， 而 不 是 该 数组 本 身 。 因 此 数组 指针 不 会 被 foreach 结构 


改变 ， 对 返回 的 数组 单元 的 修改 也 不 会 影响 源 数组 ， 不 过 源 数组 的 内 部 指针 的 确 在 处 理 数组 的 过 程 中 向 前 移动 
了 。 假定 foreach 循环 运行 到 结束 ， 源 数组 的 内 部 指针 将 指向 数组 的 结尾 。foreach 语句 不 支持 用 “@” 来 禁止 错 
误 信息 。 
高 级 | 
实 斧 
实例 059 趣味 指数 : 妇女 妇女 
图 实例 说 明 


本 实例 通过 让 条 件 语句 对 文本 框 中 输入 的 考试 成 绩 进 行 评定 和 选择 ， 运 行 结果 如 图 2.30 所 示 。 


办 六 考试 成 绩 ,|100 E23 
成 绩优 秀 上 


图 2.30 考试 成 绩 评定 标准 


图 关键 技术 


让 语句 是 最 简单 的 条 件 判断 语句 ， 它 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ; 
否则 跳 过 这 段 程序 ， 执 行 下 面 的 程序 。 

本 实例 的 关键 点 是 让 语句 的 灵活 运用 。 当 expr 的 值 为 TRUE 时 ， 执 行 statementl 语句 。 

这 expnjfstatementl3 

参数 说 明 : 

expr: 条 件 判断 语句 。 
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符合 条 件 的 执行 代码 。 
图 设计 过 程 


创建 index.php 文件 ， 当 单 击 “ 评 定 ”按钮 时 ， 程 序 自动 利用 POST 方法 接收 数据 ， 并 且 利用 站 语句 对 接收 
的 数据 进行 判断 ， 再 用 echo 语句 输出 结果 ， 其 代码 如 下 : 


statement: 


hp 
if($_POST[sub]){ 


/通过 POST 方式 传递 参数 
if($_POST[text] 一 100){ // 当 成 绩 为 100 时 
echo "成 绩优 秀 ": /输出 
if($_POST[text] >= 60 and$_ POST[text] < 100){ // 当 成 绩 大 于 等 于 60 小 于 100 时 
echo "成 绩 良 好 "; /输出 
if($_POST[text] < 60){ // 当 成 绩 小 于 60 时 
"不 及 格 ": /输出 
} 
> 
图 秘笈 心 ; 
心 法 领悟 059: 让 语句 的 变 体 。 


让 语句 有 多 种 变 体 ， 因 此 其 应 用 范围 非常 广泛 ， 


力 实例 说 明 


用 户 在 浏览 一 些 网 站 时 ， 网 站 本 身 会 将 用 户 定义 为 VIP 会 员 或 者 游客 ， 会 员 可 以 享有 更 多 的 权限 ， 而 游客 
对 网 站 的 浏览 有 权限 限制 ， 下 面 就 来 实现 这 一 功能 。 本 实例 通过 让..else.… 语 名 实现 对 登录 用 户 权限 的 控制 ， 运 
行 结 果 如 图 2.31 所 示 。 


在 后 面 的 很 多 实例 中 都 可 以 找到 它 的 身影 。 


趣味 指数 ; 容 相 页 容 


用 Ps 
二 码 :e000q| 


当前 是 YIF 用 户 


图 2.31 控制 登录 用 户 权限 


力 关键 技术 


大 多 时 候 ， 总 是 需要 在 满足 某 个 条 件 时 执行 一 条 语句 ， 不 满足 时 执行 另 一 条 语句 。 为 了 适应 这 样 的 需求 ， 
用 户 可 以 使 用 让 语句 的 else 子 句 ， 其 语法 如 下 : 


iflexpr) {statementl:}else{statement2:} 

如 果 表 达 式 expr 的 值 为 TRUE, 则 执行 statementl 语句 ; 如 果 表 达 式 expr 的 值 为 FALSE, 则 执行 statement2 
语句 。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 确 定 ”按钮 时 ， 程 序 通过 POST 方法 接收 传递 过 来 的 数据 ， 并 且 通 过 
.else.…. 选 择 语句 设 定 条件 ， 当 符合 条 件 时 利用 echo 语句 输出 “当前 是 VIP 用 户 ”， 和 否则 输出 “您 只 是 一 个 游 


91 


PHP 开发 实例 大 全 (基础 卷 ) 
客 ”， 其 代码 如 下 : 


hp 
这 $_ POST[sub]){ 
// 判 断 通过 POST 接收 的 参数 结果 是 否 符合 条 件 
这 $_ POST[muser] 一 mr and$ POST[pwd] 一 'mrsofr){ 
echo "当前 是 VIP 用 户 "; /符合 条 件 的 结果 

jslsef 

echo "您 只 是 一 个 游客 "; // 不 符合 条 件 的 结果 

J 
了 


?> 


(2) 将 该 文件 存储 于 \MR\02\060 文件 夹 中 ， 命 名 为 index php。 运 行 结果 如 图 2.31 所 示 。 


心 法 领悟 060: 使 用 站...else... 语 句 的 优点 。 
让 .else.…. 语 句 是 寺 语 句 的 另 一 种 形式 ， 结 构 上 相对 站 语 句 要 清晰 。 


ee SS 8 | 
实例 061 趣味 指数 : 依依 傅 良 | 
图 实例 说 明 


类 似 于 留言 板 等 一 些 功能 较 单一 的 网 站 ， 可 以 通过 switch 语句 制作 网 页 框架 将 所 有 内 容 包含 到 主页 中 。 本 
实例 通过 switch 语句 、include 语句 来 演示 网 页 框架 的 制作 ， 运 行 结果 如 图 2.32 所 示 。 


点 击 包含 
inc.php 文件 


Es 

;i 
x 硬是 荐 二 (各 
AN 有 < 


图 2.32 网 页 框架 的 制作 


图 关键 技术 


switch 语句 和 break 语句 的 灵活 运用 是 本 实例 的 关键 。 
(1) switch 语句 和 具有 同样 表达 式 的 一 系列 的 站 语 句 相似 。 很 多 场合 下 需要 把 同一 个 变量 (或 表达 式 ) 与 
很 多 不 同 的 值 比 较 ， 并 根据 它 等 于 哪个 值 来 执行 不 同 的 代码 ， 其 语句 格式 如 下 : 


switch(variable) { 

case valuel: 
statement]:; 
break: 

case value2: 
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default: 
default statement n: 
} 


switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比 较 ， 如 果 不 相等 ， 继 续 查 找 下 一 个 case; 如 果 
相等 , 就 执行 对 应 的 语句 , 直到 switch 语句 结束 或 遇 到 break 为 止 ,一般 switch 语句 最 终 都 有 一 个 默认 值 default， 
如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 〔 与 else 语句 类 似 ) 。 

(2) break 语句 用 于 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 利 用 switch 语句 获取 从 地 址 栏 传递 的 数据 ， 并 且 将 数据 与 switch 语句 中 
的 case 做 比较 ， 当 地 址 栏 传递 的 数据 与 case 中 的 数据 相等 时 ， 包 含 指定 文件 ， 并 且 利用 break 语句 跳出 switch 


语句 ， 其 代码 如 下 : 
<?php 
switch($_GET['link ]){ // 通 过 地 址 栏 接收 参数 
case "主页 ": // 如 果 值 为 主页 
include('ine.php); // 包 含 inephp 文件 
break; /| 结束 执行 switch 语句 
case "注册 ": // 如 果 值 为 注册 
include('ine_1.php); 
break; 
case "浏览 ": // 如 果 值 为 浏览 
include('ine_2.php); 
break; 
default: // 默 认 情况 下 ， 包 含 ine.php 文件 
include('ine.php); 
> } 
(2) 将 该 文件 存储 于 \MR\02\061 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.32 所 示 。 
图 秘笈 心 法 


心 法 领悟 061: switch 语句 的 实现 原理 。 
switch 语句 在 执行 时 ， 即 使 遇 到 符合 要 求 的 case 语句 段 ， 也 会 继续 往 下 执行 ， 直 到 switch 结束 。 为 了 避免 
这 种 浪费 时 间 和 资源 的 行为 ， 一 定 要 在 每 个 case 语句 段 后 添加 break 跳 转 语句 跳出 当前 循环 。 


实 高 级 


力 实例 说 明 


验证 码 的 作用 是 防止 用 户 亚 意 注册 而 降低 数据 库 和 网 站 本 身 的 性 能 。 本 实例 应 用 switch 语句 通过 PHP 图 像 
函数 来 演示 图 片 验 证 码 的 制作 ， 运 行 结果 如 图 2.33 所 示 。 


2.33 图 片 验证 码 
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图 关键 技术 


本 实例 的 关键 点 是 验证 码 函 数 和 switch 语句 的 联合 应 用 ， 其 应 用 到 的 函数 如 下 : 
(1) header0 函 数 
当 参 数 为 Content-type:image/png 时 使 用 header0 函 数 表示 将 图 片 输出 到 浏览 器 。 
void header ( string string [, bool replace [. int http_response_codc]]): 
(2) imagecreatetruecolor() 函 数 
新 建 一 个 真 彩色 图 像 ，imagecreatetruecolor0 函 数 返回 一 个 图 像 标识 符 , 代表 了 一 幅 大 小 为 x_size 和 y_size 
的 黑色 图 像 。 


Tesource imagecreatetruecolor ( int x_size, int y_size); 

(3) imagecolorallocate0) 函 数 

为 一 幅 图 像 分 配 颜 色 ，imagecolorallocate0) 函 数 返回 一 个 标识 符 ， 代 表 了 由 给 定 的 RGB 成 分 组 成 的 颜色 。 
image 参数 是 imagecreate() 函数 的 返回 值 ; red、green 和 blue 分 别 是 所 需要 的 颜色 的 红 、 绿 、 蓝 成 分 。 这 些 参 
数 是 0~255 的 整数 或 者 十 六 进 制 的 0x00~-0xFF imagecolorallocateO) 函 数 必须 被 调用 以 创建 每 一 种 用 在 image 所 
代表 的 图 像 中 的 颜色 。 


int innagecolorallocate (resouree inage, int ied, int green, int bie); 

(4) imagettftext0 函 数 

用 TrueType 字体 向 图 像 写 入 文本 ，imagettftext0 函 数 是 将 字符 串 text 添加 到 image 所 代表 的 图 像 上 ， 从 坐 
标 (x,y)( 左 上 角 为 (0, 0)) 开始 ， 角 度 为 angle， 颜 色 为 color， 使 用 fontfile 所 指定 的 TrueType 字体 文件 。 根 
据 PHP 所 使 用 的 GD 库 的 不 同 ， 如 果 fontfile 没有 以 "开头 ， 则 'ttf 将 被 加 到 文件 名 之 后 并 且 会 搜索 库 定 
义 字体 路 径 。 

array imagettfiext (Tesouree image, int size, int angle, int x, int y, int color, string fontfile, singtexgj; 

(5) imagegif0 函 数 

以 GIF 格式 将 图 像 输 出 到 浏览 器 或 文件 ，imagegif0 函 数 从 image 图 像 以 filename 为 文件 名 创建 一 个 
GIF 图 像 。image 参数 是 imagecreate() 函数 的 返回 值 。 

inna (resouree inage [ ting SEE 

(6) int imagestringO 函 数 

水 平地 画 一 行 字符 串 ，int imagestringO 函 数 用 col 颜色 将 字符 串 s 画 到 image 所 代表 的 图 像 的 (x,y) 坐 标 处 
(图 像 的 左上 角 为 (0, 0)) 。 如 果 font 是 1、2、3、4 或 5， 则 使 用 内 置 字体 。 

nt magestring ( resouree inage, int font, int x, nt y, stiing s, int eol); 
图 设计 过 程 

(1) 创建 index.php 文件 , 通过 GET 方式 接收 由 地 址 栏 传 递 的 数据 并 且 将 参数 与 case 的 值 进行 比较 ， 当 两 
者 相等 时 引入 指定 图 片 ， 通 过 switch 语句 进行 操作 ， 其 代码 如 下 : 


php 


switch($_GET[link]){ // 取 得 通过 地 址 栏 传递 的 参数 
cmse "文字 ": // 当 参数 等 于 文字 时 
?> 
<img sre="yzm_1.php"> // 引 入 图 片 
<?php 
break: /| 结束 执行 switch 语句 
case "数字 ": // 当 参数 等 于 数字 时 
?> 
<img sre="yzm 2.php"> // 引 入 图 片 
<?php 
break; /| 结束 执行 switch 语句 
default: // 上 默认 情况 下 
Se 
<img ste="yzm 2.php"> 
<?php 
} 
?> 
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(2) 创建 yzm_1.php 文件 ， 应 用 图 像 处 理 函 数 生成 文字 验证 码 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); 
header("Content-type:image /gif"): 

Simage = imagecreatetruecolor(80.30): 

S$font = Font FZHCJW.TTF'; 

Sbg = imagecolorallocate($image,255,255,255); 
Scolor = imagecolorallocate($image.255.,0,255); 
imagettfiext($image,20,0,8.20,$color,$font."mrsoft"); 
imagegif($image); 

?> 


/设置 文件 编码 格式 
/设置 页 面 类 型 

// 创 建 画布 

/定义 字体 

/定义 背景 颜色 


/输出 文字 
/生成 图 像 


(3) 创建 yzm_2.php 文件 ， 应 用 图 像 处 理 函 数 生成 数字 验证 码 ， 其 代码 如 下 : 


<?php 
header("Content-type:image/gif"); 
Simage = imagecreatetruecolor(40.20); 
Sbg = imagecolorallocate($image,225,225,0); 
$color = imagecolorallocate($image.255.,0,255); 
for($b = 0;$b <4; Sb ++){ 
$a =rand(1,9); 

imagestring($image,3,8,5,$a,$color); 

> 


国 秘笈 心 法 


心 法 领悟 062: 开启 GD2 支持 。 

PHP 5.0 中 GD2 函数 库 已 经 作为 扩展 被 默认 安装 ,但 目前 有 些 版 本 中 ， 还 需要 对 php.ini 文件 进行 设置 来 激 
活 GD2 函数 库 。 用 文本 编辑 工具 ， 如 记事 本 等 程序 打开 php.ini 文件 ， 将 文件 中 的 “;extension=php_gd2.dll” 选 
项 中 的 分 号 “;” 删 除 ， 保 存 修改 后 的 文件 ， 并 重新 启动 Apache 服务 器 即 可 激活 GD2 函数 库 。 


实例 063 


力 实例 说 明 


// 设 置 页 面 格式 
/生成 画布 

/定义 背景 颜色 
/定义 图 像 颜色 

// 生 成 随机 验证 码 


/输出 验证 码 
/生成 图 像 


高 级 
趣味 指数 : 究 室 家 请 


一 些 手机 在 开机 时 会 出 现 开机 问候 语 或 者 今日 日 程 提示 。 本 实例 就 是 设计 类 似 这 样 的 程序 ， 通 过 switch 语 
句 根据 当前 日 期 ， 给 出 健康 生活 提示 信息 ， 运 行 结果 如 图 2.34 所 示 。 


力 关键 技术 


2.34 ”健康 生活 提醒 


本 实例 的 关键 点 是 利用 switch 语句 ,将 地 址 栏 传递 的 数据 与 switch 语句 中 的 case 值 进行 比较 ， 符 合 条 件 的 


利用 echo 语句 输出 对 应 数据 。 
力 设计 过 程 


(1) 创建 PHP 脚本 文件 。 首 先 通过 dateO) 函 数 取 得 当前 是 星期 几 ， 然 后 利用 switch 语句 进行 操作 ， 并 通过 


echo 语句 输出 信息 提示 ， 其 代码 如 下 : 
<php 
$a = date("1"): 


// 取 得 当前 是 星期 几 


PHP 开发 实例 大 全 (基础 卷 ) 


switch(Sa){ 
case "Monday": // 当 前 如 果 是 星期 一 
echo "今天 是 星期 一 ， 一 周 忙碌 生活 开始 了 ": /输出 
break; 
case "Tuesday": // 当 前 如 果 是 星期 二 
echo "今天 是 星期 二 ， 电 视 台 下 午 两 点 以 后 部 分 休息 " /输出 
break; 
case "Wednesday": // 当 前 如 果 是 星期 三 
echo "今天 是 星期 三 ， 下 午 有 乒乓 球 比赛 "; /输出 
break; 
case "Thursday": // 当 前 如 果 是 星期 四 
echo "今天 是 星期 四 ， 晚 上 有 NBA 的 重播 "; /输出 
break: 
case "Friday": /1/ 当 前 如 果 是 星期 五 
echo "今天 是 黑色 星期 五 。。。。。。 // 输 出 
break; 
case "Saturday": // 当 前 如 果 是 星期 六 
echo "今天 是 星期 六 ， 明 天 就 放假 了 哈哈 哈 ": // 输 出 
break; 
case "Sunday": /1/ 当 前 如 果 是 星期 日 
echo "今天 是 星期 天 ， 可 以 玩 上 一 整 天 ": /| 输出 
} 
?> 
(2) 将 该 文件 存储 于 \MR\02\063 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.34 所 示 。 
力 秘笈 心 法 


心 法 领悟 063: 比较 switch 语句 与 这..else.… 语 句 。 
switch 语句 与 if.…else.…. 语 句 在 功能 上 基本 相同 ， 但 是 switch 语句 更 加 灵活 ， 格 式 更 加 鲜明 ， 结 构 更 加 
清晰 。 


2.5 循环 语句 


在 实际 应 用 中 ， 经 常会 遇 到 一 些 操作 并 不 复杂 ， 但 需要 反复 处 理 的 问题 ， 为 此 ，PHP 提供 了 循环 语句 来 实 
现 循环 结构 的 程序 设计 。 循 环 语句 是 指 能 够 按照 一 定 的 条 件 重复 执行 某 段 功 能 代码 的 代码 结构 。 循 环 语句 分 为 
以 下 4 种 : 
while 循环 语句 。 
do..….while 循环 语句 。 
for 循环 语句 。 
foreach 循环 语句 。 


实 | 
看 实例 说 明 


while 循环 结构 的 作用 是 重复 执行 一 段 代 码 或 完成 相同 的 动作 。 本 实例 通过 while 语句 循环 输出 数组 中 存储 
的 员工 生日 信息 ， 运 行 结 果 如 图 2.35 所 示 。 


回回 回回 
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86 年 6 月 ?日 是 张 ? 的 生日 


图 2.35 员工 生日 列表 


图 关键 技术 


while 循环 是 PHP 中 最 简单 的 循环 语句 。while 循环 语句 根据 某 一 条 件 进 行 判 断 ， 决 定 是 否 执行 循环 ， 其 语 
法 格式 是 : 

while (expn){ 

statement 

} 

当 表 达 式 expr 的 值 为 TRUE 时 ， 将 执行 statement 语句 ， 执 行 结束 后 ， 再 返回 到 expr 表达 式 继续 进行 判断 。 
直到 表达 式 的 值 为 FALSE 才 跳 出 循环 ， 执 行 大 括号 后 面 的 语句 。 


图 设计 过 程 
创建 index.php 文件 。 首 先 ， 利 用 数组 函数 将 数据 信息 存储 在 数组 变量 中 。 然 后 ， 定 义 循环 变量 的 初始 值 为 


0， 最 大 值 不 超过 数组 长 度 ， 并 在 循环 内 部 做 自 增 运算 。 最 后 ， 利 用 while 循环 输出 结果 ， 其 代码 如 下 : 
<?php 
$a=array("86 年 6 月 1 日 是 张 1 的 生日 ""86 年 6 月 2 日 是 张 2 的 生日 ""86 年 6 月 3 日 是 张 3 的 生日 ""86 年 6 月 4 日 是 张 4 的 生日 ""86 
年 6 月 4 日 是 张 4 的 生日 ""86 年 6 月 5 日 是 张 5 的 生日 ""86 年 6 月 6 日 是 张 6 的 生日 ""86 年 6 月 7 日 是 张 ?的 生日 ""86 年 6 月 7 日 是 张 ?7 


的 生日 "); // 定 义 数组 
$b=0; // 给 变量 赋 初 始 值 
while($b < count($a){ // 根 据 数组 长 度 循环 输出 
echo $a[$b]."<br><br>"; /输出 数组 元 素 
Sb++: 
} 
> 
国 秘笈 心 法 


心 法 领悟 064: 介绍 while 语句 的 变 体 。 
while 循环 语句 还 有 另 一 种 表示 形式 ， 即 do...while， 详 细 说 明 请 参见 实例 065。 


| 


: 


实例 065 趣味 指数 : 窒 广 食 三 


力 实例 说 明 
本 实例 通过 do while 循环 语句 循环 读 取 数据 库 中 的 数据 ,输出 员工 的 详细 信息 ， 运 行 结果 如 图 2.36 所 示 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


所 在 地 址 :Qs 


期 ，1986-06-06 所 1 


姓名 ， 部 请 年龄， ee 0000-00-00 人 
幅 名, 黄 葵 年 训 册 ， 


图 2.36 员工 详细 信和 浏览 


图 关键 技术 


while 语句 还 有 另外 一 种 表示 形式 ， 即 do...while。do...while 循环 语句 和 while 循环 语句 非常 类 似 ， 只 是 
do.…while 循环 语句 在 循环 底部 检测 循环 表达 式 ， 而 不 是 在 循环 的 顶部 进行 检测 。do.…while 循环 语句 的 语法 格 
式 如 下 : 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 mysql_connect0 函 数 连 接 MySQL 数据 库 ， 并 通过 mysql_query0 函 
数 定义 页 面 的 编码 格式 。 然 后 ， 定 义 SQL 查询 语句 并 返回 结果 集 。 最 后 ， 通 过 do.…while 语句 循环 输出 数据 库 
中 的 数据 ， 其 代码 如 下 : 
<?php 


$conn = mysql_connect("localhost", "root","111") // 连 接 数 据 库 服务 器 
mysql_select_db("db_database02", $conn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"): // 设 置 编码 格式 
Srs = mysql_query("select * from tb_while"); // 执 行 查询 

dof 


echo "姓名 : "iconv(gbk'vutf-8'\Srst[1])."&nbsp:&nbsp: 年 龄 : "iconv(gbk' utf-8',Srst[2])."&nbsp:&nbsp: 出 生日 期 ; 
"iconv('gbk','utf-8',$rst[3])."&nbsp;&nbsp; 所 在 地 址 : ".iconv('gbk','utf-8',$rst[4])."&nbsp;&nbsp:QQ: ".iconv('gbk','utf-8',$rst[5])."<br><br>"; 
}while($rst = mysql_fetch_array($rs)): 
> 


(2) 将 该 文件 存储 于 \MR\02\065 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.36 所 示 。 
图 秘笈 心 法 
心 法 领悟 065， 使 用 do...while 语句 的 注意 事项 。 


在 使 用 do…while 语句 之 前 ， 要 考虑 程序 是 否 有 必要 在 判断 条 件 之 前 运行 一 次 ， 如 果 没有 必要 ， 尽 量 不 要 
使 用 该 语句 ， 否 则 可 能 会 出 现 意外 的 输出 结果 。 


实例 066 趣味 指教 : 容 全 全 全 


国 实例 说 明 


在 操作 数据 库 的 过 程 中 可 能 会 出 现 很 多 无 用 的 元 余 信息 ， 可 以 使 用 
while 循环 语句 将 其 循环 删除 。 本 实例 通过 while 循环 语句 实现 员工 信息 的 批 
量 删 除 ， 运 行 结果 如 图 2.37 所 示 。 


删除 3 | 条 记录 国际 ] ) 


图 2.37 员工 信息 的 批量 删除 
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图 关键 技术 


本 实例 的 关键 点 是 while 循环 语句 的 灵活 运用 。 根 据 提交 的 参数 值 ， 执 行 while 循环 语句 ， 在 循环 体 中 执行 
删除 操作 ， 完 成 数据 的 循环 删除 操作 。 


国 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 连 接 MySQL 数据 库 服务 器 ， 选 择 MySQL 中 名 称 为 db_while 的 数据 库 ， 


并 设置 页 面 的 编码 格式 。 然 后 ， 定 义 循环 变量 ga 和 $b， 将 第 一 层 while 循环 中 的 循环 条 件 设置 为 Sb<$a， 然 后 ， 
再 次 利用 while 语句 循环 输出 数据 表 中 的 数据 ， 并 执行 数据 的 删除 操作 ， 其 代码 如 下 : 


<2php 
if($_POST[sub) { /通过 POST 方式 获取 参数 
S$conn = mysql_connect("localhost", "root","111"); // 连 接 MySQL 数据 库 
mysql_select_db("db_while", Sconn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"); // 定 义 编码 格式 
$a=$_POST[te]: // 接 收文 本 框 参数 
$b=0; // 定 义 变量 
while($b < $a){ //while 循环 
Srs = mysql_query("select + from tb_while"); // 执 行 查询 操作 
while($rst = mysql_fetch_array(Srs)){ // 将 查询 结果 保存 在 数组 中 
$sql = "delete + from tb_while where id = $b"; /SQL 语句 
mysql_query($sq)); // 执 行 删 除 操作 
echo "姓名 为 ".Srstfname]." 的 员工 已 被 删除 <br>"; /输出 被 删除 的 员工 姓名 
Sbt+t; 
1 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\066 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.37 所 示 。 
>» 
图 秘笈 心 法 


心 法 领悟 066: 使 用 while 语句 嵌 套 的 注意 事项 。 
while 循环 语句 允许 语句 嵌 套 ， 但 在 嵌 套 的 过 程 中 要 注意 保持 层次 结构 的 清晰 。 


| 高 级 | 
全 | 
二 | “六 ei tieded 
实例 加 四 回国 四 国 加 加 | 
图 实例 说 明 
很 多 时 候 PHP 编码 需要 和 HTML 编码 混 编 , 例如 , 输出 表格 打印 HTML 标签 

等 。 本 实例 应 用 两 层 for 语句 循环 制作 动态 表格 ， 运 行 结 果 如 图 2.38 所 示 。 


图 关键 技术 2.38 表格 的 动态 创建 


for 循环 语句 能 够 按照 已 知 的 循环 次 数 进行 循环 操作 ， 主 要 应 用 于 多 条 件 情况 下 的 循环 操作 ， 不 适合 在 单一 
条 件 下 使 用 。 这 一 点 从 该 语句 的 语法 中 就 可 以 看 出 ， 其 条 件 的 表达 式 有 3 个 ， 语 法 格式 如 下 : 

for (sxprl; expr2: expr3){ 

statement; 

} 

其 中 ,exprl 为 变量 初始 赋值 ;expr2 为 循环 条 件 , 即 在 每 次 循环 开始 前 求 值 ,如果 其 值 为 真 , 则 执行 statement， 
否则 ， 跳 出 循环 ， 继 续 往 下 执行 ，expr3 为 变量 递增 或 递减 ， 即 每 次 循环 后 被 执行 。 


PHP 开发 实例 大 全 《基础 卷 ) 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 for 循环 中 的 循环 变量 Sa。 设 定 Sa 的 初始 值 为 0， 最 大 值 为 4， 并 且 


每 执行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 利 用 循环 嵌 套 的 知识 定义 内 层 循环 ， 内 层 循环 的 循环 变量 Sb 的 初始 
值 为 0， 最 大 值 为 7， 并 且 同 样 做 自 增 运算 。 最 后 ， 利 用 echo 语句 输出 信息 ， 其 代码 如 下 : 


<php 
for(Sa= 0:$a < 5;5at+){ 作 层 for 循环 
echo "<table border='1'bordercolor=#000099' bordercolorlight=#000099' cellspacing=0'>"; 
bo // 表 格 标签 
for($b = 0:Sb < 8:$b++){ /2 层 for 循 环 
echo "<td>"; /表格 标签 
echo $b: /输出 数据 
echo “</td>"; 
La ct 
echo "</table>"; 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\067 文件 夹 下 ， 命 名 为 ndex.php。 和 运行 结果 如 图 2.38 所 示 。 
图 秘笈 心 法 


心 法 领悟 067: for 循环 语句 。 
for 循环 语句 在 PHP 循环 结构 中 比较 常用 ， 结 构 也 比较 简单 ， 所 以 一 定 要 灵活 掌握 此 循环 语句 。 在 本 实例 
中 ， 虽 然 其 定义 变量 的 最 大 值 分 别 为 4 和 7， 但 是 由 于 在 for 循环 中 ， 其 条 件 表达 式 的 值 是 从 等 于 0 开始 ， 所 以 
循环 语句 分 别 执行 了 5 次 和 8 次 。 
高 级 : 


力 实例 说 明 


购物 车 是 电子 商务 系统 中 的 常见 模块 ，SESSION 作为 一 种 会 话机 制作 用 不 可 小 凯 。 本 实例 综合 运用 while 
语句 、switch 语句 、 让 语句 和 for 语句 实现 一 个 简单 的 SESSION 购物 车 功能 ， 运 行 结果 如 图 2.39 所 示 。 


会 牌 折 优 惠 ! 


图 2.39 SESSION 购物 车 中 数据 的 读 取 
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图 关键 技术 


(1) 通过 switch 语句 根据 地 址 栏 中 传递 的 参数 值 ， 实 现在 不 同 商品 页 面 之 间 的 跳 转 。 
(2) 通过 让 语句 对 form 表单 提交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 
(3) 通过 while 语句 和 for 语句 完成 购物 车 中 购买 商品 的 输出 。 


设计 过 程 
(1) 创建 index.php 文件 ， 通 过 switch 语句 根据 地 址 栏 中 传递 的 参数 值 ， 实 现在 不 同 商品 页 面 之 间 的 跳 转 ， 


其 代码 如 下 : 
php 
switch($_GET[link]){ 
case "电脑 ": 
include once("in 1.php"); 
break; 
case "家 庭 影院 ": 
include_once("in_2.php"); 


break; 

case "全 自动 洗衣 机 ": 
include_once("in_3.php"); 
break; 


case "数码 摄像 机 ": 
include_once("in_4.php"); 
break: 


case "山地 自行 车 ": 

include_once("in_5.php"); 

break; 

default: 

include_once("in_image.php"); 
是 


?> 
(2) 创建 config.php 文件 。 首 先 ， 编 辑 form 表单 ， 执 行 不 同 的 操作 。 然 后 ， 应 用 站 语句 根据 form 表单 提 
交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 最 后 ， 通 过 while 和 for 语句 循环 输出 购物 车 中 存储 的 商品 ， 其 关键 代 
码 如 下 : 


<form action="" method="post"> 
我 要 购买 <input type="text" size="2" value ="1" name="num"> 件 
<input type="submit" name="sub" value=" 放 入 购物 车 " style="background-image:url(pic/button_2.jpg);color:red"> 
<input type="submit" name="sub1" value=" 结 账 " style="background-image:url(pic/button_3.jpg);color:red"> 
<input type="submit" name="sub2" value=" 首 页 " style="background-image:url(pic/button_1.jpg):color:red"> 
</form> 
<2php 
if($_POST[sub2D){ 
echo "<script>location.href='index.php'</seript>"; 


} 
if($_POST[sub){ 
$str = explode("#",$_SESSION[id]): 
include("class/mysql.php"); 
$sql = "insert into tb_shop(id.name.number.money.moneyother.other)values(".$str[O].$str[1]','$str[2]''$str[3]"$str[4])": 
iftmysql_query($sql){ 
mysql_close($conn); 
echo "<script>alert(' 已 经 放 入 购物 车 )</script>": 
} 


} 

if($_POST[sub1] || $_GET['sub1D{ 
require_once("class/mysql.php"): 
$sq = "select * from tb_shop"; 
Srs =mysql query($sq): 


<form action ="config/table.php" method="post"> 
<input type="submit" name="sub3" value=" 删 除 " style="background-image-url(pic/button_3.jpg):color:red"> 
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</form> 
<?php 
while(Srst = mysql_fetch_row(Srs)) 
for($a = 0:$a < 6;$a++){ 


> 
<tr><td><?php echo Srst[$a]?></td></tr> 
<?php 
> 
</table> 
<a href="config/money.php"><img sre="pic/bu jpg"></a> 
<php 
} 
?> 
(3) 创建 table php 文件 ， 执 行 删除 指定 商品 的 操作 ， 其 关键 代码 如 下 : 
<php 
require_once("../class/mysql.php"); // 包 含 数据 库 连 接 文 件 
$sq = "select * from tb_shop"; /定义 SQL 查询 语句 
Srs= mysql_query(Ssq); /执行 查询 操作 
?> 
<table> 
?php 
while($rst = mysql_fetch_row($rs){ // 循 环 输出 商品 信息 
> 
<tr><td> 商 品 编码 : <?php echo $rst[0]:?></td><td> 商 品名 称 : <?php echo $rst[1]:;?></td></tr> 
<tr><td> 购 买 数量 :<?php echo Srst[2]:?><hr></td><td> 金 额 总 计 : <?php echo S$rst[3]:?><hr></td></tr> 
<!--tr><td> 商 品 运费 :<?php echo Srst[4];?><hr></td><td> 其 他 声明 ; <?php echo $rst[5]:?><hr></td></tr--> 
<php 
} 
> 
<itd> 
</tr></table></td></tr></table> 
<2php 
if($ POST[sub4D)f 
$sqlser = "delete from tb_shop where id ='$_POST[tt]": // 定 义 SQL 语句 
if(mysql_query($sqlser){ // 执 行 删除 操作 
echo "<script>alert( 商 品 删除 成 功 ")</script>"; 
echo "<script>window .location.href="table.php':</seript>"; 
} 


) 
if($_POST[subS){ 
echo "<script>window.location href="../index.php?link= 电 脑 &sub1=1";</script>"; 


} 
bo 

(4) 编辑 mysql.php 文件 ， 实 现 与 数据 库 的 连接 。 

航 心 法 
心 法 领悟 068: 知识 对 接 。 
购物 车 的 知识 相对 较 复杂 ， 在 本 书 第 5 章 的 实例 266 中 将 对 购物 车 进行 详细 讲解 。 

高 级 | 

9 趣味 指数 : 妇女 太太 


实例 069 


力 实例 说 明 


员工 信息 一 般 存 在 于 人 事 信息 平台 的 后 台 系统 中 ， 对 员工 信息 的 管理 本 身 可 以 作为 一 个 典型 的 模块 被 使 用 。 
本 实例 通过 for 循环 语句 实现 对 员工 数据 的 读 取 、 修 改 和 删除 操作 ， 运 行 结 果 如 图 2.40~ 图 2.42 所 示 。 
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图 2.40 员工 数据 的 读 取 


未 自 http://le 


at 


图 2.42 员工 数据 的 修改 


力 关键 技术 


本 实例 通过 for 循环 语句 读 取 查询 结果 集中 的 数据 ,完成 数据 的 循环 输出 ,并且 创建 删除 和 修改 超 链 接 ， 应 
用 站 语句 对 超 链接 传递 的 参数 值 进 行 判 断 ， 实 现 对 数据 的 删除 和 修改 操作 。 有 关 for 循环 语句 的 详细 说 明 请 参 
见 实例 067， 站 语句 的 详细 讲解 请 参见 实例 059。 


图 设计 过 程 
创建 index.php 文件 。 首 先 ， 连 接 MySQL 数据 库 执行 查询 操作 取得 查询 结果 集 。 然 后 ， 通 过 for 语句 循环 
输出 结果 集中 的 数据 。 最 后 ， 通 过 让 语句 对 超 链接 的 参数 值 进行 判断 ， 进 而 执行 删除 和 修改 操作 ， 其 关键 代码 


如 下 : 
<?php 
Slink = mysql_pconnect("localhost", "root", "111"); // 连 接 MySQL 
mysql_select_db("db_database02".$link): // 连 接 数 据 库 
mysql_query("SET NAMES GBK"): /设置 编码 格式 
Squery = "SELECT * FROM tb_for_1"; //SQL 语句 
Sresult = mysql_query($query): // 执 行 查询 操作 
for ($i= mysql_num rows($result) - 1: Si>= 0; $i--) { //for 循环 
if(lmysql_data_seek($result. Si) { // 如 果 指 针 不 向 下 移动 
echo "Cannot seek to row $i: " . mysql_error0 . "\n"; 
continue; 
} 
if(!(S$row = mysql_fetch_object($result))) // 如 果 结果 集 不 存在 
continue: 
echo "<tr><td>$row->name</td><td>$row->age</td><td>$row->sex</td><td>$row->tel</td><td>$row->address</td> 
<td><a href='1.php?id=$row->id&delete=1><b> 删 除 </b></a>&nbsp:&nbsp:<a hre 人 ="1.php?id=$row->id&update=1'><b> 修 改 
<lb></a></td></tr>"; 
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4 
mysql_free_result($result); /释放 结果 集 
if($_GET[delete] — D{ // 如 果 地 址 栏 参数 delete 等 于 1 
$sql = "delete fromtb for 1 where id='$ GET[id]"; JWSQL 语句 
if(mysql_query($sqD)){ /执行 删除 操作 
echo "<script>alert( 删 除 成 功 );location href="1.php'</script>": /| 提示 框 信息 
区 
} 
if($_GET[update] 一 D{ // 如 果 地 址 栏 参数 update 等 于 1 
$sql = "select * from tb_for_1 where id =$_GET[id]"; //SQL 语句 
Srs =mysql_query($sql); /| 执行 查询 语句 
Srst =mysql fetch_array($rs); /取得 结果 集 
> 
</table><br><br> 
<form action="" method="post"> // 表 单 
// 使 文本 框 初始 值 为 数据 库 中 结果 
<input name="name" type="text" value="<?php echo $rst[name]:?>" size="6"> 
<input name="age" type="text" value="<?php echo Srst[agel]:?>" size="6"> 
<input name="sex" type="text" value="<?php echo S$rst[sex]:?>" size="6"> 
<input name="tel" type="text" value="<?php echo S$rst[tel]:?>" size="11"> 
<input name="address" type="text" value="<?php echo $rst[address]:?>" size="6"> 
<input type="submit" name="sub1" value=" 修 改 "> 
</form></td></tr></table></td></tr></table> 
php 


if($_POST[sub1D{ // 如 果 按 钮 被 单 击 
$sql = "update tb_for 1 set name ='$_ POST[name].age ='$_POST[age]',sex ='$_POST[sex]',tel ='$_POST[tel] ,address = 
'$_POST[address]' where id = 号 GET[id]"//sql 语句 


这 mysql_query($sqD){ /执行 更 新 操作 
echo "<script>alert(' 修 改 成 功 ):location.href="1 .php'</script>"; /提示 框 信息 
} 


} 


2> 


国 秘笈 心 法 


心 法 领悟 069: 使 用 地 址 栏 传递 参数 存在 风险 。 
通过 地 址 栏 传递 参数 是 存在 风险 的 ， 一 般 情况 下 应 使 用 POST 方式 传递 参数 。 如 果 一 定 要 使 用 GET 方式 传 
递 参数 ， 最 好 应 用 urlencode0 函 数 对 参数 进行 编码 。 


实例 070 


力 实例 说 明 


在 编程 世界 里 ， 算 法 是 一 门 独立 于 语法 、 函 数 之 外 的 知识 ， 它 着 重 考验 用 户 的 逻辑 思维 能 力 并 且 与 数学 知 
识 息 息 相 关 。 本 实例 通过 for 循环 语句 实现 网 页 版 九 九 乘法 表 ， 运 行 结果 如 图 2.43 所 示 。 


#1 =1 

2 * 1 =2|2 #2.=4 

3 #1=33*2=6 1 

1 = 机 28 =12|4 #4 =16 


5 * 1 =5l5 * 2kztols +:3 =15l5 + 4 =20l5 * 5 5325 广 2 + 
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图 2.43 ”网 页 版 九 九 乘法 表 
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国 关键 技术 
本 实例 的 关键 点 是 利用 for 循环 中 的 第 2 层 循环 控制 第 1 层 循环 ， 以 实现 指定 数据 的 输出 。 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 定 义 第 1 层 循环 中 的 循环 变量 为 a， 设置 $a 的 初始 值 为 !， 最 大 值 为 9，， 并 且 每 


执行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 定 义 内 层 循环 中 的 循环 变量 为 Sb， 设 置 Sb 的 初始 值 为 1， 最 大 值 小 于 
$a， 并 且 做 自 增 运算 。 最 后 ， 将 第 2 层 循环 控制 的 数据 输出 到 页 面 ， 其 代码 如 下 : 


php 
for($a= 1:$a < 10:$a++){ // 第 1 层 循环 
echo "<tr>"; 
for($b= 1;$b <= $a;$b++){ // 第 2 层 循环 控制 第 1 层 循环 输出 
echo "<td>"; 
echo "$a * $b =".$a*$b; /1/ 输 出 结果 
echo"</td>"; 
J “</tr>"; 
> 
(2) 将 该 文件 存储 于 \MR\02\070 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.43 所 示 。 
国 秘笈 心 ; 
心 法 领悟 070: 形成 良好 的 算法 思维 。 
算法 不 是 一 朝 一 夕 就 可 以 掌握 的 ， 是 一 个 慢 慢 了 解 、 形 成 思想 的 过 程 。 


趣味 指数 : 仿 食 全食 
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实例 说 明 


用 户 在 进行 开发 时 ， 没 有 必要 将 小 型 的 数据 与 数据 库 进行 交互 ， 可 以 直接 将 其 存 入 数组 ， 这 样 不 仅 可 以 节 
约 开发 时 间 ， 还 可 节省 服务 器 资源 。 本 实例 通过 对 数组 函数 的 相关 操作 实现 读 取 数 组 购物 车 中 的 数据 ， 运 行 结 
果 如 图 2.44 所 示 。 


短 黄 : 30 元 《自理 》 
图 2.44 实现 读 取 
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图 关键 技术 


本 实例 的 关键 点 是 运用 foreach 语句 遍历 数组 ， 取 得 key 值 和 对 应 的 value 值 。foeach 循环 在 PHP 4.0 中 擅 
长 处 理 数 组 ， 是 遍历 数组 的 一 种 简单 方法 ; 在 PHP 5.0 中 ， 新 增加 了 对 对 象 的 支持 。 该 语句 的 语法 格式 如 下 ; 


foreach (array expression as $value) 
Statement 


或 
foreach (amray expression as $key => $value) 
statement 


foreach 语句 将 遍历 数组 array_expression, 每 次 循环 时 , 将 当前 数组 中 的 值 赋 给 $value (或 是 $key 和 $value) ， 
同时 ， 数 组 指针 向 后 移动 直到 遍历 结束 。 当 使 用 foreach 语句 时 ,数组 指针 将 自动 被 重 置 ， 所 以 不 需要 手动 设置 
指针 位 置 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 字符 串 变量 ， 并 且 在 变量 中 插入 “#” 作 为 字符 串 分 割 点 。 然 后 ， 利 
用 GET 方式 接收 地 址 栏 传递 的 参数 。 当 $_GET[push] 的 值 等 于 1 时 ， 输 出 JavaScript 成 功 提示 。 当 $_GET[pop] 


的 值 等 于 1 时 ， 利 用 字符 串 拆 分 函数 将 字符 串 变 量 以 “# ”分 割 ， 并 分 别 保存 到 数组 中 。 最 后 ， 利 用 foreach 语 
句 将 字符 串 数组 中 的 value 值 输出 到 页 面 中 ， 其 代码 如 下 : 


hp 
$str = "宝贝 ， 液 晶 电 脑 显示 器 # 一 口 价 ，900 元 # 运 费 ，30 元 (自理 ) "; // 定 义 字 符 串 
if($_GET[push] = 1){ // 通 过 GET 方式 取得 参数 
echo "<script>alert( 成 功放 入 购物 车 ");</script>"; // 提 示 消 息 
J) 
if($_GET[pop] =— D{ // 通 过 GET 方式 取得 参数 
S$strexplode = explode("#",$str): // 分 割 字 符 串 
foreach($strexplode as Skey => $value){ /遍历 数组 
> 
<tr><td><?php echo $value:?></td></tr> // 输 出 结果 
<?php 


} 
} 
x 


(2) 将 该 文件 存储 于 \MR\02\071 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.44 所 示 。 
力 秘笈 心 法 


心 法 领悟 071: 对 于 foreach 语句 的 说 明 。 
foreach 语句 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 
语句 不 支持 用 “@ ”来 禁止 错误 信息 。 


力 实例 说 明 


用 户 注册 后 ， 系 统 为 了 保存 用 户 的 一 些 基本 信息 ， 包 括 用 户 名 、 密 码 等 相 
关 信 息 ， 以 及 跟踪 和 定位 不 同 用 户 从 而 更 好 地 服务 于 用 户 ， 同 时 为 了 提高 站 点 
的 安全 性 ， 避 免 由 于 网 速 慢 造成 用 户 注册 信息 的 重复 提交 ， 往 往 会 在 用 户 注册 
表 中 增加 验证 码 功 能 。 本 实例 通过 for 循环 实现 图 像 验证 码 的 生成 ， 运 行 结 果 ”图 2.45 图 像 验 证 码 的 生成 
如 图 2.45 所 示 。 


有 
高 级 | 
| 去 友 | 
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图 关键 技术 
本 实例 的 关键 点 是 for 循环 语句 和 rand0 函 数 的 灵活 运用 。 通 过 for 循环 输出 一 个 包含 4 个 图 像 的 验证 码 ， 
验证 码 的 取 值 由 随机 函数 rand0 生 成 。 


rand0 函 数 可 产生 一 个 随机 整数 ， 其 语法 如 下 : 

intrand ( [int min, int max] ) 

如 果 没 有 提供 可 选 参数 min 和 max，rand0 函 数 返回 0 到 RAND_MAX 之 间 的 伪 随 机 整数 。 例 如 ， 想 得 到 
2~8 (包括 2 和 8) 之 间 的 随机 数 ， 则 写 为 rand(2, 8)。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 数组 函数 定义 数组 并 分 别 将 图 片 的 地 址 信息 存 入 数组 中 。 然 后 ， 在 


for 循环 的 循环 体内 ， 利 用 随机 函数 取得 0~3 中 的 随机 数字 并 保存 在 变量 Srand 中 。 最 后 ， 利 用 拼接 字符 串 的 方 


法 输出 图 片 ， 其 代码 如 下 : 
<?php 


Sarray = array("pic/22.jpg","pic/3 jpg"."pic/4.jpg"."pic/S.jpg"): // 定 义 数组 
for($a= 0:$a < 4;$a++){ //for 循环 
Srand = rand(0,3); //0~3 的 随机 数字 
echo "<img sre = '$array[Srand]>"; // 输 出 图 像 


} 


?> 

(2) 将 该 文件 存储 于 \MR\02\072 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.45 所 示 。 
力 秘笈 心 法 

心 法 领悟 072: 图 像 验 证 码 的 刷新 。 

在 本 实例 中 ， 通 过 重新 链接 到 首页 来 实现 验证 码 的 刷新 操作 。 


2.6 跳 转 语 句 


跳 转 控制 语句 包括 break 和 continue 两 个 。 其 中 break 语句 可 以 终止 当前 的 循环 ， 而 continue 语句 只 能 终止 
本 次 循环 ， 并 进入 下 一 次 循环 中 。 


高 级 


实例 073 趣味 指教 : 容 食 食 三 


i 


图 实例 说 明 
break 语句 的 含义 是 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 本 实例 通过 break 
语句 实现 控制 页 面 中 表情 图 的 输出 ， 运 行 结果 如 图 2.46 所 示 。 
6 查获 0 嘲笑)o EJ 
已 
图 2.46 控制 页 面 中 表情 图 的 输出 


力 关键 技术 
使 用 break 关键 字 可 以 终止 当前 的 循环 , 包括 while、do...while、for、foreach 和 switch 在 内 的 所 有 控制 语句 ， 
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其 在 for 语句 中 的 应 用 示例 如 下 : 
for($i=1;$1<=4;$i++){ // 应 用 for 循环 控制 语句 输出 表情 头像 
if($i==4){ // 判 断 变量 是 否 等 于 4 
[ee // 如 果 等 于 4， 使 用 break 语句 跳 转 循环 


} 
本 实例 将 break 语句 与 switch 语句 联合 使 用 ， 控 制 页 面 中 表情 图 的 输出 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “确定 ”按钮 时 ， 利 用 switch 语句 选择 输出 的 图 片 并 通过 break 语句 跳出 
当前 switch 语句 ， 其 代码 如 下 : 
<opl 


hp 
i($_GET[sub){ // 通 过 GET 方式 接收 参数 

switch($_GET['check D){ /lswitch 语句 
case "1": // 如 果 值 为 1 
echo "<img sre='image/1 .gif >"; /输出 图 像 1 
break; // 跳 出 语句 
case "2": // 如 果 值 为 2 
echo "<img src='image/2.gif>"; /输出 图 像 2 
break // 跳 出 语句 
Cae": // 如 果 值 是 3 
echo "<img sre='image/3.gif>"; /输出 图 像 3 
break: // 跳 出 语句 
case "4": // 如 果 值 为 4 
echo "<img sre='image/4.gif >"; /输出 图 像 4 
break; // 跳 出 循环 

} 

} 
> 
(2) 将 该 文件 存储 于 \MR\02\073 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.46 所 示 。 
> 0 
力 秘笈 心 法 


心 法 领悟 073: break 语句 的 妙用 。 
break 语句 可 以 接受 一 个 可 选 的 数字 参数 来 决定 跳出 几 重 循环 。 


宗 高 级 | 
实例 074 趣味 指数 : 请 禄 庚 庚 | 
实例 说 明 


break 语句 可 以 指定 跳出 循环 的 层 数 ， 一 般 被 用 在 控制 条 件 方面 。 本 实例 通过 break 语句 实现 控制 页 面 中 数 
据 的 输出 数量 ， 运 行 结果 如 图 2.47 所 示 。 


加 六 SD 本 DD 
EEEXZZN) 
图 2.47 控制 页 面 中 数据 的 输出 数量 
力 关键 技术 
本 实例 运用 break 语句 跳出 指定 的 几 重 循环 ， 其 语法 格式 如 下 : 
break n: 
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图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 多 重 for 循环 霸 套 输出 全 部 图 片 。 然 后 ， 在 多 重 嵌 套 中 定义 并 条 件 语 
句 ， 当 变量 Srand 中 的 随机 数值 为 2 时， 跳出 3 重 循环 ， 否 则 正常 输出 图 片 ， 其 代码 如 下 : 


hp 
for($a = 0:$a < 2:Sat+jf 咱 层 循环 
for($b = 0:$b < 2:$b++){ /人 2 层 循环 
for($c= 0:Sc< 4:$c+Hf //3 层 循环 
Srand = rand(1.4): /11~4 随机 数字 
echo "<img src=image/Srand_gif>": /输出 图 像 


} 
} 


} 
echo "<hr style='color:blue;>"; 


for($a= 0;$a <2;$at+){ 省 层 循环 
for($b = 0:$b < 2:$b++){ /全 层 循环 
for($c=0;$c < 4:$c++){ //3 层 循环 
Srand = rand(1,4); /~4 随机 数字 
if($rand (=2){ /条 件 语句 
echo "<img src=image/Srand gif>"; /| 输出 图 像 
jelsef 
break 3; /| 结束 3 个 层级 的 循环 


} 
} 
?> : 
(2) 将 该 文件 存储 于 \MR\02\074 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.47 所 示 。 
力 秘笈 心 法 
心 法 领悟 074: 灵活 运用 跳 转 语句 。 
跳 转 语句 一 定 要 灵活 运用 。 常 用 的 跳 转 语句 包括 break 语句 和 continue 语句 ，continue 语句 将 在 后 面 的 实例 
中 做 详细 介绍 。 


i 高 级 
实例 075 趣味 指数 : lolol 
力 实例 说 明 


在 循环 结构 中 ， 有 些 数据 是 不 需要 的 ， 想 要 跳 过 这 些 代 码 向 下 执行 就 需要 用 到 continue 语句 。 本 实例 通过 
continue 语句 实现 动态 改变 页 面 中 单元 格 的 背景 颜色 ， 运 行 结 果 如 图 2.48 所 示 。 


动态 交 公 
图 2.48 动态 改变 页 面 中 单元 格 的 背景 颜色 


图 关键 技术 


在 程序 执行 break 后 ， 程 序 将 跳出 循环 执行 流程 开始 继续 执行 循环 体 的 后 续 语句 。continue 跳 转 语句 的 作用 
没有 break 那么 强大 ，continue 只 能 终止 本 次 循环 而 进入 下 一 次 循环 中 。 在 执行 continue 语句 后 ， 程 序 将 结束 本 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
次 循环 的 执行 ， 并 开始 下 一 轮 循环 的 执行 操作 。continue 跳 转 语句 的 流程 控制 如 图 2.49 所 示 。 


continue 


图 2.49 continue 流程 控制 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 for 循环 定义 循环 变量 的 初始 值 为 0， 最 大 值 为 9， 并 且 每 执行 完 一 
次 循环 ， 循 环 变量 做 一 次 自 增 运算 。 然 后 ， 利 用 让 语句 定义 条 件 ， 当 循环 变量 小 于 等 于 5 时 ， 通 过 dechex() 函 


数 获 取 6 个 十 六 进 制 随机 数 ， 和 否则 终止 本 次 循环 。 最 后 ， 将 取得 的 6 个 十 六 进 制 数 添加 到 <table> 标 签 的 bgcolor 
属性 中 ， 实 现 动态 变色 ， 其 代码 如 下 : 


<2php 


for($b = 0:Sb < 10:$b++){ // 循 环 语句 
isSb <= 5){ /| 条 件 语句 
Srand.= dechex(rand(0,15)); /取得 6 个 十 六 进 制 数 
jelsef 
continue; // 不 满足 条 件 ， 重 新 执行 循环 
} 
} 
> 


<table height="55" bgcolor="#<?php echo Srand:?>">// 设 置 背 景 颜色 
<tr><td width="156"></td> 
</tr></table> 


(2) 将 该 文件 存储 于 \MR\02\075 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.48 所 示 。 
国 秘笈 心 法 
心 法 领悟 075: continue 语句 的 妙用 。 
continue 语句 也 可 以 指定 跳 转 层 级 数 。 
高 级 


趣味 指数 : 依依 依 良 


实例 076 | 


力 实例 说 明 
数学 中 有 这 样 一 道 题 ， 取 得 0~10 中 所 有 偶数 或 者 奇数 的 和 。 如 果 想 把 这 道 题 用 PHP 代码 表示 出 来 ， 则 需 
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要 使 用 跳 转 语句 continue 来 完成 。 本 实例 通过 跳 转 语句 continue 实现 屏蔽 偶数 次 的 数据 输出 , 运行 结果 如 图 2.50 
所 示 。 


a hs nh 
B#1=3/3 * 9 3 #7 =21|3 #27 
#1 =5[5 3E15 Et 7 =35|5 "9/245 
Wr 1 =7[7*"3 D1| [FF =49[r * 363 
9 *1 =9|9 * S20 #5 zd5[9 *# 7 =63|9 *# 9581| 


1 #7=7 | #9=9 


图 2.50 ”屏蔽 偶数 次 的 数据 输出 


力 关键 技术 
本 实例 的 关键 点 是 continue 语句 的 灵活 运用 ， 详 细 说 明 请 参见 实例 075。 
图 设计 过 程 
创建 PHP 脚本 文件 。 首 先 通过 for 循环 语句 动态 输出 HTML 的 <tr> 标 签 和 数据 ， 并 且 当 循环 变量 为 偶数 时 


终止 本 次 循环 。 然 后 ， 利 用 相同 的 方法 动态 输出 HTML 的 <td> 标 签 和 数据 。 最 后 ， 在 页 面 中 输出 如 图 2.50 所 示 
的 表格 ， 其 代码 如 下 : 


for($a= 1:$a < 10:$at+){ 作 层 循环 
if($a % 2— 0){ // 如 果 为 偶数 则 回 到 本 循环 开始 位 置 
continue; 
"<tr>"; 
for($b = 1:$b < 10:$b++){ /2 层 循环 
if$b %2!=0){ // 如 果 为 偶数 
echo "<td>"; 
echo "$a * $b =".$a+$b; /| 输出 结果 
echo "</td>"; 
jelsef 
continue; // 回 到 本 循环 的 开始 位 置 
} 
} 
nfte>" 
} 
> 
力 秘笈 心 法 


心 法 领悟 076: 求 余 运 算 符 。 
利用 “%” 运 算 符 可 取得 两 个 数 的 余数 ， 本 实例 通过 该 运算 符 判 断 是 否 为 偶数 ， 如 果 想 要 判断 是 否 为 奇数 ， 
只 需 将 条 件 设 定 为 不 等 于 1 即 可 。 


力 实例 说 明 
本 实例 通过 continue 语句 实现 跳 过 数据 输出 中 指定 的 记录 ， 运 行 结果 如 图 2.51 所 示 。 
力 关键 技术 


本 实例 应 用 continue 语句 跳 过 指定 的 循环 ， 输 出 指定 循环 以 外 的 数据 。 
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0、PHP 典 型 模块 a 
8 PHP 开 发 实战 宝 | 
Jee 二 Il 
和 PHP 网 络 编程 自学 手 ~ 


锁 入 要 跌 过 记录 的 编号 
《PHP 典 型 模块 》 后 网 络 编程 自学 于 几 》 


图 2.51 跳 过 数据 输出 中 指定 的 记录 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 一 个 数组 存储 数据 ， 然 后 定义 下 拉 列 表 ， 其 中 下 拉 列表 的 值 由 PHP 代 
码 动态 添加 ， 当 输入 跳 过 记录 的 编号 并 单 击 “ 跳 过 ”按钮 时 ， 利 用 continue 语句 ， 输 出 不 包含 指定 数据 的 其 他 
数据 ， 其 代码 如 下 : 


/定义 数组 
Sarray = array("PHP 典型 模块 "PHP 开发 实战 宝典 ""Java 开发 实战 宝典 "."PHP 网 络 编程 自学 手册 "); 


<form action="" method="pos 

<textarea name="te" ole="20 rows="6">0、<?php echo Sarray[0]:?> 1、 <?php echo $array[1]:?> 2、 <?php echo $array[2]:?> 
3、<?php echo Sarray[3]:?> 

</textarea><br> 

<input type="text" name="text" value=" 输 入 要 跳 过 记录 的 编号 "size="20" onFocus="this.value=""> 

<input type="submit" name="subl" value=" 跳 过 "> 


</form> 
<7 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
for($a = 0;$a < count($array):$a++){f /| 循环 数组 
if($a — $_POST[text){ // 当 $a 等 于 文本 框 中 的 数据 时 回 到 循环 开始 位 置 
continue: 
Jelse{ 
& 各 
echo $array[$a]; /| 输出 数组 元 素 
echo » ie 
} 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\077 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.51 所 示 。 
图 秘笈 心 法 


心 法 领悟 077: 在 HIML 中 插入 PHP 代码 。 
PHP 代码 可 以 插入 到 HIML 页 面 的 任何 位 置 ， 也 可 以 插入 到 HTML 的 任何 一 个 可 行 性 标签 中 。 


环 


力 实例 说 明 
本 实例 利用 break 语句 实现 执行 指定 次 数 的 循环 ， 运 行 结果 如 图 2.52 所 示 。 
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7 


已 经 输出 1 次 循环 
已 经 输出 2 次 循环 
已 经 输出 3 次 循环 守 浊 


2.52 ”执行 指定 次 数 的 循环 


图 关键 技术 
本 实例 利用 break 语句 可 以 跳出 循环 并 终止 循环 的 特点 ， 控 制 循环 执行 的 次 数 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 当 单 击 “ 执 行 ”按钮 时 ， 首 先 ， 定 义 for 循环 语句 ， 设 定 循环 变量 $a 的 初始 值 


为 0， 并 且 每 执行 一 次 循环 ，$a 做 一 次 自 增 运算 。 然 后 ， 通 过 让 语句 定义 条 件 ， 如 果 $a 大 于 等 于 文本 框 中 输入 
的 数字 时 ， 跳 出 当前 循环 ， 否 则 输出 字符 串 ， 其 代码 如 下 : 
pl 


hp 
if($_POST[sub1D{ /通过 POST 方式 传递 参数 
for($a = 0;$a < 10000000000000:Sa++jf /循环 
这 $a >= $_POST[text){ // 接 收文 本 框 信息 判断 条 件 
break: /| 结束 循环 
Jelse{ // 否 则 循环 输出 


echo "已 经 输出 "($a+1)." 次 循环 <br>"; 
} 
} 


2> 


(2) 将 该 文件 存储 于 WMR\02\078 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.52 所 示 。 
图 秘笈 心 法 
心 法 领悟 078: 流程 控制 语句 。 


流程 控制 语句 包括 条 件 控制 语句 、 循 环 控制 语句 和 跳 转 控制 语句 ， 是 PHP 的 重要 组 成 部 分 也 是 PHP 程序 
员 必须 重点 掌握 和 理解 的 内 容 。 


2.7 自 定 义 函 数 


在 开发 过 程 中 ， 经 常 需要 多 次 重复 某 种 操作 或 处 理 ， 如 数据 查询 、 字 符 操作 等 。 如 果 每 个 模块 都 要 重新 输 
入 一 次 代码 ， 不 仅 加 大 了 程序 员 的 工作 量 和 开发 时 间 ， 而 且 对 于 代码 的 后 期 维护 及 运算 效果 也 有 很 大 影响 。 使 
用 自 定义 函数 就 是 解决 该 问题 的 最 有 效 的 方法 。 


实例 079 


力 实例 说 明 
截取 字符 串 在 程序 设计 中 是 经 常 出 现 的， 例如 ， 截 取 增 、 删 、 改 、 查 SQL 语句 的 前 6 个 字符 进行 判断 ， 以 便 
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进行 增 、 删 、 改 、 查 等 操作 。 本 实例 应 用 substr0 函 数 实现 用 自 定义 函数 截取 中 文字 符 串 ， 运 行 结果 如 图 2.53 所 示 。 


图 2.53 ” 自 定义 函数 截取 中 文字 符 串 


图 关键 技术 


substr0 函 数 用 于 从 字符 串 中 按照 指定 位 置 截 取 一 定 长 度 的 字符 ， 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 。 如 果 使 用 一 个 正 数 作为 子 串 的 起 点 来 调用 这 个 函数 ， 将 得 到 从 起 点 到 字符 串 结束 的 整个 字符 串 ; 
如 果 使 用 一 个 负数 作为 子 串 的 起 点 来 调用 ， 将 得 到 原 字符 串 尾部 的 一 个 子 串 ， 字 符 个 数 等 于 给 定 负数 的 绝对 值 。 


substrO 函 数 的 语法 如 下 : 
string substr ( string str, int start [, int length]): 


参数 str 用 来 指定 字符 串 对 象 ， 参 数 start 用 来 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末 
尾 开 始 截取 ， 参数 length 为 可 选项 ， 指 定 截取 字符 的 个 数 ， 如 果 为 负数 ， 则 表示 截取 到 倒数 第 length 个 字符 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 定 义 自 定义 函数 ， 当 单 击 “ 截 取 ” 按 钮 时 ， 利 用 substr0 函 数 对 指定 字符 串 进行 
截取 并 输出 蕉 取信 息 ， 其 代码 如 下 : 

es function strO{ // 自 定义 函数 str0 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
$a=" 自 定义 函数 截取 中 文字 符 串 我 是 被 截取 的 部 分 "， ” /定义 字符 串 变量 
S$rs = substr($a,(2+$_POST['text]-2).(2*$_POST['text_1"])); /截取 字符 串 

: echo S$rs; /输出 截取 结果 


strO; // 自 定义 函数 调用 


?> 
(2) 将 该 文件 存储 于 \MR\02\079 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.53 所 示 。 
国 秘笈 心 ; 


心 法 领悟 079: substr0 函 数 的 特点 。 
substr0) 函 数 支持 从 右 侧 取 值 ， 例 如 : 
<php 


$a ="abcdef"; /定义 字符 串 
Srs = substr($a.-2.1): /从 右 侧 取 值 
echo $rs; /输出 截取 结果 


> 
经 正 浏 览 器 运行 ， 显 示 结 果 为 e。 


力 实例 说 明 
本 实例 通过 字符 串 截取 函数 和 自 定义 函数 实现 公告 标题 的 截取 ， 运 行 结果 如 图 2.54 所 示 。 
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ow 


融雪 全 办 移 开 守 第 二 王 天 
南非 世界杯 正 进 行 的 如 火 如 茶 
二 Po 


图 2.54 公告 标题 的 截取 


图 关键 技术 


自 定义 函数 ， 顾 名 思 义 是 由 用 户 自 行 定义 并 完成 指定 功能 的 函数 。 自 定义 函数 的 产生 是 由 于 程序 员 在 进行 
日 常 开发 时 ， 使 用 PHP 预定 义 的 函数 并 不 能 实现 理想 的 功能 。 程 序 员 人 迫切 希望 能 够 根据 自己 程序 的 实际 情况 自 
行 定义 完成 指定 功能 的 函数 。 创 建 函 数 的 基本 语法 格式 如 下 : 


function fraction name ([$arg_1],[Sarg_ 2], … ,[Sarg_n]){ 


} 

参数 说 明 : 

function: 声明 自 定义 函数 时 必须 使 用 的 关键 字 。 

function_name: 创建 函数 的 名 称 ， 是 有 效 的 PHP 标识 符 。 函 数 名 称 是 唯一 的 ， 其 命名 遵守 与 变量 命名 相同 
的 规则 ， 只 是 不 能 以 “$” 开 头 。 

arg_1.…arg_n: 是 外 界 传递 给 函数 的 值 ， 可 有 可 无 ， 也 可 以 有 多 个 ， 数 量 根据 需要 而 定 ， 各 参数 用 逗号 “,” 
分 隔 。 参 数 的 类 型 不 必 指 定 ， 在 调用 函数 时 只 要 是 PHP 支持 的 类 型 都 可 以 使 用 。 

fun_body: 自 定义 函数 的 主体 ， 是 功能 实现 部 分 。 

retum: 将 调用 的 代码 需要 的 值 返 回 ， 并 结束 函数 的 运行 。 

在 本 实例 中 ， 定 义 自 定义 函数 str0， 地 和 中 行人， 其 语法 如 下 : 


function str($st) { 定义 函数 
$a = strlen($str); 人 
$b = substr($str,0,$a); 1/ 截取 字符 串 
echo $b: /输出 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 定 义 数组 ， 当 单 击 “获取 标题 ” 超 链接 时 ， 调 用 自 定义 函数 str0 对 数组 中 的 元 
素 进行 截取 ， 并 输出 截取 后 的 标题 信息 ， 其 代码 如 下 : 
<7 


// 定 义 数组 
Sarray = array(" 南 非 世界 杯 开赛 第 十 五 天 "." 南 非 世界 杯 正 进行 得 如 火 如 茶 ， 头 号 种 子 队伍 巴西 戏 勇 善战 ， 取 得 了 良好 成 绩 。"); 
?> 


<table border="1" bordercolor="#CCCCCC"cellspacing="0" width="290" height="251" align="center” background-"2.jpg"> 
<tr><td width="208" align="center"> 
<b style="font-family: 文 易 霹 雳 体 : font-size:18px; color:#0033CC"><?php echo $array[0]:?></b><br> 
<b style="font-family:' 方 正 新 报 宋 简体 '; font-size:14px: color#0033CC">&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:<?php echo 
Saray[1]:?></b><br> 


<a hre 人 "index.php?sub= 获 取 " style="float:center"> 获 取 标 题 </a> // 定 义 超 链接 
<htd> 
</tr><tr><td align="center"><b style="color:#F0000; font-family:' 方 正 细 圆 繁体 "> 
<?php 
这 $_GET[sub] 一 "获取 "){ // 通 过 GET 方式 获取 参数 


ls 


str(Sarmray[0]): 
} 


function str($str) { 
$a = strlen($str); 
Sb = substr($str,0,5a); 
echo $b: 

} 


?> 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


// 调 用 自 定义 函数 


// 自 定义 函数 

1/ 计算 字符 串 长 度 
// 截 取 字 符 串 
/输出 


(2) 将 该 文件 存储 于 \MR\02\080 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.54 所 示 。 


心 法 领悟 080: 自 定义 函数 的 应 用 注意 事项 。 


自 定义 函数 的 名 称 是 不 区 分 大 小 写 的 ， 而 常量 和 变量 的 名 称 区 分 大 小 写 。 


力 实例 说 明 


ea 


高 级 | 


赵 味 指数 ， 寅 查 宙 宣 | 


开发 论坛 程序 很 重要 的 一 点 是 转换 空格 符 和 回 车 符 , 因为 不 是 所 有 的 论坛 用 户 都 知道 HTML 标签 “&nbsp;” 
和 <br> 的 作用 ， 大 多 数 用 户 都 喜欢 用 空格 和 回 车 对 文本 进行 控制 ， 这 就 需要 程序 员 人 为 地 做 到 统一 。 本 实例 通 
过 自 定义 函数 定义 转换 方法 实现 论坛 内 容 的 简短 输出 ， 运 行 结 果 如 图 2.55 所 示 。 


力 关键 技术 


标题 下 
TI 编程 你 好 
PHP 编 程 


内 容 : | [RE 
提交 + 


AORsE/ 
标题 :PHP 
内 容 : PEP 编 程 ` 你 好 P 王 编程 谢谢 您 


2.55 ”论坛 内 容 的 简短 输出 


本 实例 通过 自 定义 函数 实现 对 字符 串 中 空格 符 和 回 车 符 的 转换 输出 ,在 自 定义 函数 中 应 用 的 是 preg_replaceO 


函数 。 自 定义 函数 的 语法 如 下 : 
function str($st) { 


Sstr = preg_replace("/ /"."&nbsp:",$str); 
Sstr = preg_replace("/cha(13)/","<br>".$str): 


echo "内 容 : ".$str; 
} 


力 设计 过 程 


// 自 定义 函数 
// 普 换 空格 

// 普 换 回 车 符 
/输出 


(1) 创建 PHP 脚本 文件 ， 通 过 自 定义 函数 定义 对 “&nbsp;” 和 回 车 进行 蔡 换 ， 当 单 击 “提交 ”按钮 时 ， 
首先 对 文本 框 是 否 存在 内 容 进行 判断 ， 如 果 文本 框 内 容 不 为 空 ， 调 用 自 定义 函数 并 输出 文本 信息 ， 其 代码 如 下 : 
< 


hp 
function str($str){ 


Sstr = preg_replace("/ /"."&nbsp:".$str): 
Sstr = preg_replace("/cha(13)/","<br>".$str); 


echo "内 容 : ".$str; 


} 
isS_POST[sub]){ 


/如 果 text 为 空 或 者 文本 域 和 下 拉 列 表 框 同时 为 空 


116 


// 自 定义 函数 
// 莹 换 空格 

// 普 换 回 车 符 
/输出 


// 通 过 POST 方式 传递 参数 


第 2 章 PHP 基础 


if($ 1 a 一 ”|(S_ POST[t] 一 ”) && ($_POST[check] — D){ 


echo "<script>alert( 内 容 不 能 为 空 ):location hre 人 index.php'</script>": /输出 提示 
jelsef 

这 $_POST[select] (= "1){ /当下 拉 列 表 框 值 不 等 于 1 时 
echo "标题 : ".$_POST[text]."<br>"; /输出 内 容 和 下 拉 列 表 框 内 容 
str($_POST[te].$_POST[check]); 

Jelse{ 
echo "标题 : ".$_POST[text]."<br>"; /否则 只 输出 文本 域内 容 
str($_POST[te]); 


} 
} 


(2) 将 该 文件 存储 于 \MR\02\081 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.55 所 示 。 
秘笈 心 法 
心 法 领悟 081， 对 于 实例 代码 的 重要 说 明 。 


上 例 代 码 中 “$_POST[text] = 一 "|| (($_POST[te] 一 "") && ($_ POST[check] 一 1))” 是 存在 运算 符 优先 级 的 ， 
为 了 避免 发 生 错 误 ， 笔 者 将 先进 行 的 运算 加 上 了 小 括号 。 


EO i 
ee | 
国 实例 说 明 


用 户 在 论坛 上 发 表 或 者 回复 留言 时 可 能 会 遇 到 这 种 情况 ， 单 击 “ 发 布 ”按钮 时 ， 系 统 提示 使 用 了 禁用 词语 ， 
禁止 发 布 。 这 是 论坛 的 开发 人 员 为 了 规范 论坛 而 采用 的 过 滤 字 符 串 的 手段 。 本 实例 通过 自 定义 函数 实现 过 滤 字 
符 串 ， 运 行 结 果 如 图 2.56 所 示 。 


图 2.56 自 定义 函数 过 滤 字 符 串 


图 关键 技术 
本 实例 编写 自 定义 函数 str0 对 字符 串 进行 过 滤 ， 如 果 出 现 指定 的 关键 词 ， 则 给 出 提示 信息 并 终止 程序 执行 。 
自 定义 函数 str0) 的 语法 如 下 : 
function str($str) { 
$array = array(' 图 书 ', 明 日 科技 ,软件 ,编程 词典 ,编程 词典); /定义 数组 
Srepstr = implode($array): // 数 组 转换 成 字符 串 
ifpreg 1 mete Srepstr){ // 正 则 表达 式 验 证 字符 串 
echo "<seript>alert(' 您 使 用 了 禁用 词语 ， 请 重新 填写 ):location hre 全 index.php'</script>"; 
jslse{ 
echo "内 容 为 : ".$str: // 输 出 数据 
} 
} 


ul 


PHP 开发 实例 大 全 (基础 卷 ) 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 自 定义 函数 ， 将 禁用 词语 保存 在 数组 中 ， 并 通过 字符 串 函数 拆 分 数组 ， 


利用 正则 表达 式 函数 对 禁用 词语 进行 屏蔽 。 当 单 击 “提交 ”按钮 时 ， 调 用 自 定义 函数 对 提交 内 容 进 行 过 滤 ， 并 
输出 提示 信息 ， 其 代码 如 下 : 


<?php 
function str($str){ 
$array = array(' 图 书 ',' 明 日 科技 ,软件 "编程 词典 "编程,' 词 典 ); // 定 义 数组 
Srepstr = implode($array); // 数 组 转换 成 字符 串 
iflpreg_match("/$str/", Srepstr){ // 正 则 表达 式 验证 字符 串 
echo "<seript>alert( 您 使 用 了 禁用 词语 ， 请 重新 填写 ):location href="index.php'</script>"; 
Jelse{ 
echo "内 容 为 :".$str; /输出 数据 
} 
if($_POST[sub){ 
str($_POST[te]); // 调 用 自 定义 函数 


2> 


(2) 将 该 文件 存储 于 \MR\02\082 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.56 所 示 。 
图 秘笈 心 法 


心 法 领悟 082: 过 滤 程 序 。 
本 实例 只 是 简单 地 介绍 了 字符 串 过 滤 的 原理 ， 真 正 的 过 滤 程 序 由 于 数据 量 较 大 ， 需 要 将 数据 存储 在 数据 库 
中 。 如 果 读 者 感 兴趣 ， 可 以 将 其 与 数据 库 中 的 数据 结合 使 用 。 


2.8 字 符 串 


在 许多 Web 编程 中 ， 字 符 串 总 是 会 被 大 量 地 生成 和 处 理 。 正 确 地 使 用 和 处 理 字符 串 ， 对 于 PHP 程序 员 来 
说 越 来 越 重 要 。 


趣味 指数 : 伍 食 福全 


实例 083 


力 实例 说 明 


由 于 各 个 用 户 所 使 用 的 输入 法 不 同 或 者 个 人 习惯 的 原因 ， 有 可 能 不 经 意 间 多 输入 了 空格 或 者 特殊 字符 ， 造 
成 网 站 内 容 的 输出 不 美观 。 本 实例 通过 ltrim0 和 rtrim0 函 数 实现 去 除 字符 串 中 的 空白 和 特殊 字符 ， 运 行 结 果 


如 图 2.57 所 示 。 
和 中 区 昌 
去 除 字 符 申 二 你 好 VPHP 东 秽 
2.57 去除 字符 串 中 的 空白 和 特殊 字符 
图 关键 技术 
(1) ltrim0 函 数 


使 用 ltim0 函 数 默认 情况 下 去 除 左边 空格 ， 去 除 特殊 字符 的 参数 可 选 。 
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string ltrim ( string str [, string charlist]); 
参数 说 明 : 
string str: 源 字符 串 信 息 。 
string charlist: 可 选 参数 ， 特 殊 字符 。 

(2) rtrim0 函 数 
使 用 rtrim0 函 数 默 认 情 况 下 去 除 右边 空格 ， 去 除 特殊 字符 的 参数 可 选 。 
string rtrim ( string str [, string charlist]); 
参数 说 明 : 
string str: 源 字 符 串 信息 。 
string charlist: 可 选 参数 ， 特 殊 字符 。 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 定 义 字符 串 变量 Sa, 分别 通过 ltrim() 和 rtrim() 函 数 去 除 两 边 的 空格 和 特殊 字符 并 
显示 结果 ， 其 代码 如 下 : 


<php 
$a="(:@_@ 你 好 ! PHP 范例 @_@:)"; // 声 明 一 个 带 空格 和 特殊 字符 的 字符 串 变量 
Sb = ltrim($a); // 去 除 变 量 左 边 的 空格 
$c=1tim($b,"(:@_@"); // 去 除 变量 左边 的 特殊 字符 
Sd =rtrim(Se); // 去 除 变 量 右边 的 空格 
Se=rtrim($d,"@ _@:)"): // 去 除 变 量 右边 的 特殊 字符 
echo "去 除 字符 串 空白 和 特殊 字符 前 : ".$a."<br>"; 
echo "去 除 字符 串 空白 和 特殊 字符 后 : "Se; /输出 最 后 结果 
?> 
(2) 将 该 文件 存储 于 \MR\02\083 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.57 所 示 。 
图 秘笈 心 法 


心 法 领悟 083: 使 用 ltrim0 和 rtrim0 函 数 的 相关 说 明 。 
在 使 用 这 两 个 函数 时 ， 默 认 情 况 下 是 只 去 除 左边 或 者 右边 的 空格 ， 想 要 去 除 特殊 字符 ， 需 要 在 函数 里 注 明 。 


实例 084 


趣味 指数 : 依依 依依 


国 实例 说 明 


论坛 帖子 中 的 单 引号 和 双 引 号 在 未 经 转 义 的 情况 下 输出 会 出 现 问 题 ,特别 是 在 输出 SQL 语句 时 。 本 实例 通 
过 addslashes0 函 数 来 实现 转 义 字符 串 ， 运 行 结果 如 图 2.58 所 示 。 


未 经 转 头 的 字符 申 玫 P! 入 语句 归 INstRi"TNio + ,yA TY ) 
经 转 义 后 的 字符 帅 入 语句 s INSERTy INTD +t IE VALUBS OMN, Yonigline\ 


2.58 ” 转 义 字符 串 


力 关键 技术 


本 实例 主要 是 通过 addslashesO) 函 数 对 指定 的 SQL 语句 进行 自动 转 义 。addslashes() 函 数 可 以 转 义 单 引 号 、 双 
引号 、 反 斜 本 、NULL 字符 ， 主 要 用 于 SQL 语句 ， 对 部 分 字符 进行 转 义 ， 其 语法 如 下 : 

string addslashes ( string str); 

参数 说 明 : 

string str: SQL 语句 。 
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图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 插入 型 SQL 语句 ， 然 后 将 SQL 语句 通过 addslashes0 函 数 转 义 并 显示 


转 义 结果 ， 其 代码 如 下 : 
<?php 


$str = "INSERT INTO db(iduserpwdjlast_dateJVALUES(1,yangv*yysy.2010-06-03)": 。“// 声 明 一 个 字符 串 变量 
echo "未 经 转 义 的 字符 串 :".$str."<br>"; // 未 经 转 义 
echo "经 转 义 后 的 字符 串 : ".addslashes($str); /| 经 转 义 

Ss 


(2) 将 该 文件 存储 于 WMR\02\084 文件 夹 中 ， 命 名 为 index php。 运 行 结果 如 图 2.58 所 示 。 


心 法 领悟 084: addslashes0 函 数 在 程序 中 的 应 用 。 
addslashes0 〇 函数 主要 用 于 数据 库 SQL 语句 的 转 义 ， 当 数据 要 插入 至 数据 库 之 前 ， 有 必要 应 用 addslashes( 
函数 进行 字符 串 转 义 ， 以 免 特殊 字符 未 经 转 义 在 插入 数据 库 时 出 现 错误 。 


高 级 | 


实例 085 趣味 指数 ， 宙 本 女 刘 ， 


图 实例 说 明 


既然 可 以 将 帖子 内 容 进行 转 义 ,当然 也 可 以 将 帖子 内 容 进行 还 原 。 本 实例 通过 stripslashes0 函 数 来 实现 还 原 
字符 串 ， 运 行 结果 如 图 2.59 所 示 。 


未 经 还 原 的 字符 钊 。 入 性 梧 全 INSERTIOINID + ,yAL ESN , ns\ 午 
经 还 原 后 的 字符 帅 : 入 语句 s INSERT/INID +t ,rae VAL IESC WO Y ) 


图 2.59 还 原 字符 串 


力 关键 技术 


本 实例 运用 stripslashesO 函 数 ， 将 addslashes0 函 数 转 义 的 字符 串 进行 还 原 ， 其 语法 如 下 : 
string stripslashes ( string str); 

参数 说 明 : 

string str: SQL 语句 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 定义 数据 库 插入 语句 的 字符 串 变 量 ， 然 后 将 字符 串 变 量 通过 stripslashesO 
函数 还 原 并 显示 运行 结果 ， 其 代码 如 下 : 

<2php 


$str = "INSERT INTO db(id.user.pwd .last_date)VALUES('1'.yang'.******"'2010-06-03”)"; 。“ // 声 明 一 个 字符 串 变 量 


echo "未 经 还 原 的 字符 串 : ".$str."<br>"; /未 经 还 原 字符 串 输出 
echo "经 还 原 后 的 字符 串 : ".stripslashes($str)."<br>"; /| 经 还 原 后 的 字符 串 输 出 
?> 
(2) 将 该 文件 存储 于 \MR\02\085 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.59 所 示 。 
图 秘笈 心 法 


心 法 领悟 085: stripslashes0 函 数 的 应 用 。 
stripslashes() 函 数 主要 用 于 数据 库 SQL 语句 的 还 原 输出 。 
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实例 086 


图 实例 说 明 
本 实例 通过 substr0 函数 实 现 截取 论坛 标题 ， 运 行 结果 如 图 2.60 所 示 。 
| 起 取 论坛 标题 | 
本 论坛 标题 ;s 截 取 论 坛 
截取 的 字符 囊 ;e 截取 论 
图 2.60 截取 论坛 标题 
图 关键 技术 


substr() 函 数 用 于 从 字符 串 中 按照 指定 位 置 截取 一 定 长 度 的 字符 ， 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 。substr0 函 数 的 详细 讲解 请 参见 实例 079。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 变量 $a 并 将 网 页 标题 赋 给 Sa， 然后 通过 substr0 函 数 对 字符 串 $a 进行 堆 
取 ， 并 输出 截取 内 容 ， 其 代码 如 下 : 

<?php 


$b = "截取 论坛 标题 "; // 设 定 字符 串 
$a = "<title>$b</title>"; // 设 定 网 页 标题 
echo $a; /输出 字符 串 
echo "本 论坛 标题 :".$b."<br>"; /输出 论坛 标题 
$b = substr($b.0.12); /截取 论坛 标题 
echo "截取 的 字符 串 :".$b; /| 输 出 截取 内 容 


> 


(2) 将 该 文件 存储 于 WMR\02\086 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.60 所 示 。 
国 秘笈 心 法 
心 法 领悟 086: substr0 函 数 应 用 的 注意 事项 。 


substr() 函 数 的 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 1 个 字符 表示 为 0。 该 函数 在 截取 
中 文字 符 串 时 可 能 会 出 现 乱码 ， 所 以 建议 在 对 中 文字 符 串 进行 截取 时 应 用 mb_substr0 函 数 。 


图 实例 说 明 


字符 串 的 分 割 、 合 成 对 于 程序 员 来 说 是 十 分 重要 的 ， 应 用 也 十 分 广泛 。 例如， 在 遍历 数据 库 查找 匹配 项 时 
就 会 用 到 合成 函数 ， 而 购物 车 程序 一 般 会 用 到 分 割 函数 。 本 实例 通过 explode0 函 数 和 implode0 函 数 实现 分 割 、 
合成 字符 串 ， 运 行 结果 如 图 2.61 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


原 字 符 串 ， 你 好 PHEN 很 你 。 
经 分 割 后 的 数组 为 ] => 你 好 PHP 丰 ] 六 很 你 .0 
合成 后 的 字符 串 2 你 : < 认识 你 = 


图 2.61 分割、 合成 字符 串 


图 关键 技术 


字符 串 的 分 割 与 合成 应 用 的 是 explode0 函 数 和 implodeO 函 数 。 
(1) explode0 函 数 


explode0) 函 数 按照 指定 的 规则 对 一 个 字符 串 进行 分 割 ， 返 回 值 为 数组 ， 其 语法 如 下 : 

array explode ( string separator, string string [, int limit]); 

参数 separator 表示 指定 的 分 隔 符 ，string string 表示 分 割 条 件 ，int limit 表示 指定 生成 数组 的 最 大 值 。 
(2) implodeO 函 数 

implode() 函 数 与 explodeO 函 数 配合 使 用 ， 将 数组 的 内 容 组 合成 一 个 字符 串 ， 其 语法 如 下 : 


string implode ( string glue, array picees]: 


参数 glue 是 字符 串 类 型 ， 指 定 分 隔 符 ， 参 数 pieces 是 数组 类 型 ， 指 定 要 被 合并 的 数组 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 字符 串 变量 ， 将 字符 串 内 容 用 指定 的 分 隔 符 分 隔 。 然 后 利用 explode0 


函数 ， 将 字符 串 变 量 按照 规定 的 分 隔 符 分 割 ， 并 保存 在 数组 变量 $explode 中 。 最 后 分 别 利用 prinr r0 函 数 和 
implode0 函 数 输出 数组 和 字符 串 ， 其 代码 如 下 : 


<?php 


$str =" 你 好 PHP 很 高 兴 认识 你 。": /定义 字符 串 

$explode = explode(" ".$str); // 分 割 字符 串 

echo " 原 字符 串 ; "$str."<br>"; /输出 原 字符 串 

echo "经 分 割 后 的 数组 为 “: 

print_r(Sexplode); // 打 印 分 割 后 的 数组 

echo "<br> 合 成 后 的 字符 串 :"; 

echo implode($explode); // 将 数组 合成 为 字符 串 
> 


(2) 将 该 文件 存储 于 \MR\02\087 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.61 所 示 。 
图 秘笈 心 法 


心 法 领悟 087: explode0 函 数 和 implode0 函 数 哪个 应 用 更 广泛 。 
二 者 相 比 ，implode0 函 数 应 用 相对 广泛 ， 所 有 的 数组 变量 都 可 以 用 它 进行 


中 


成 。 


实例 088 


趣味 指数 : 二 全 真相 | 


力 实例 说 明 


关键 字 描 红 技术 广泛 应 用 于 站 内 搜索 或 者 高 级 搜索 中 ， 是 一 项 很 常用 的 技术 。 本 实例 通过 str_replace0 函 数 
实现 查询 关键 字 描 红 ， 运 行 结 果 如 图 2.62 所 示 。 
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oogle_ Yahoo: 
! 


2.62 ”查询 关键 字 描 红 


图 关键 技术 
str_replace 0) 函数 可 用 于 执行 字符 串 蔡 换 操作 ， 其 语法 如 下 : 


mixed str replace ( mixed scarch mixed replace, mixed subject [, int &count] ) 
参数 说 明 : 

search: 必要 参数 ， 指 定 需 要 查找 的 字符 串 。 

replace: 必要 参数 ， 指 定 蔡 换 的 值 。 

subject: 必要 参数 ， 指 定 查找 范围 。 

count， 可 选 参数 ， 获 取 执 行 蔡 换 的 数量 。 


力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 将 通过 POST 方式 接收 到 数据 ， 首 先 对 数据 进行 描 红 
处 理 ， 然 后 应 用 str_replaceO 函 数 对 指定 字符 串 信息 的 指定 内 容 进行 蔡 换 ， 其 代码 如 下 : 


<2php 


if($ POST[subD{ 
$a = "<b style='color:red;font-size:18px:>".$_POST[text]."</b>"; // 对 提交 的 关键 字 进行 描 红 
echo str_replace("$_POST[text]",$a,Sstr); /完成 字符 串 的 普 换 操作 
?> 


(2) 将 该 文件 存储 于 \MR\02\088 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.62 所 示 。 
图 秘笈 心 法 


心 法 领悟 088: 更 多 实现 关键 字 描 红 的 函数 。 
不 仅 可 以 通过 str_replaceO) 函 数 实现 关键 字 的 描 红 操作 ， 还 可 以 通过 str_ireplace0 函 数 实现 对 关键 字 的 描 红 
功能 ， 并 且 该 函数 不 区 分 大 小 写 。 


实例 089 


趣味 指数 : 袜 食 食 伍 


国 实例 说 明 
在 站 内 搜索 中 ， 往 往 要 求 列 出 符合 条 件 的 关键 字 有 多 少 个 。 本 实例 通过 字符 串 函 数 substr_count0 统 计 查询 
关键 字 出 现 的 次 数 ， 运 行 结果 如 图 2.63 所 示 。 


被 袖 索 的 文本 sw Pi 
网 公司 5oogle， 


和 寓 索 | pf A nh : NA 2006 芝 万 个 动态 网站 垃 用 
hbo, eBey 并 
其 键 字 ，| 
De ea 1 pe A ti ey 


shoo、s8ay 和 电 屋 知 记 况 站 拜访 、 百 度 、 同 里 已 四 条 
居 楼 宇 出 现 2 次 = > = 


2.63 估计 查询 关键 字 出 现 的 次数 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 
本 实例 通过 substr_ count0 函 数 检索 字符 串 子 串 出 现 的 次 数 。substr_count0 函 数 的 语法 如 下 : 


int substr_count ( string haystack, string needle ) 
参数 说 明 : 

string haystack: 源 字符 串 。 

string needle: 字符 串 子 串 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 , 首先 定义 字符 串 变 量 , 编写 form 表单 。 当 单 击 “ 搜 索 ” 按 钮 时 , 利用 substr_count() 
函数 输出 指定 字符 串 子 串 的 出 现 次 数 ， 其 代码 如 下 : 
~ echo "<a style='font-size:20px; color:#000000> 被 搜索 的 文本 : </a>"; // 定 义 字符 串 输出 


$str = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知名 
互联 网 公司 Google、Yahoo、eBay 和 中 国 知 名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采用 PHP 技术 ! "; 


echo $str."<br>"; 
?> 
<form action ="" method="post"> /表单 
关键 字 ， <input type="text" name="text"><input type="submit" name="sub" value =" 搜 索 "> 
</form> 
</body> 
</html> 
<?php 
ee /通过 POST 方式 传递 参数 
= "<b style='color:red:font-size: 18px:>".$_POST[text]."</b>"; // 普 换 后 的 字符 串 
人 :replace("$_POST[text]",$a,$str)."<br>"; // 莹 换 字符 串 
// 统 计 关键 字 出 现 次 数 


echo "关键 字 出 现 <b style='color:red:font-size:22px:>".substr_count($str,$_POST[text])."</b> 次 。"; 
} 


?> 
(2) 将 该 文件 存储 于 \MR\02\089 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.63 所 示 。 
图 秘笈 心 法 


心 法 领悟 089: substr_count0) 函 数 的 实现 原理 。 
substr_count0 函 数 是 一 种 类 似 全 文 检索 的 函数 ， 其 原理 是 检索 查找 匹配 的 字符 串 ， 返 回 匹 配 次 数 。 


图 实例 说 明 
文件 上 传 功能 几乎 是 所 有 网 站 所 必 备 的 ， 然 而 文件 上 传 对 于 服务 器 来 说 具有 很 大 风险 ， 因 此 应 该 对 文件 大 
小 、 文 件 类 型 进行 限制 。 本 实例 通过 字符 串 函数 strev0 获 取 上 传 文件 的 后 缀 ， 运 行 结果 如 图 2.64 所 示 。 
殿 键 字 jp: Vly Docments\ 范 例 大 [| 上 千 
后 缀 为 :doc 
图 2.64 获取 上 传 文件 的 后 缀 


趣味 指数 : 伍 广 寅 食 


转 关键 技术 
PHP 中 字符 串 的 逆序 输出 可 以 通过 循环 实现 ， 但 最 简单 的 方式 是 通过 strev0 函 数 实现 。strrev0 函 数 可 将 字 
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符 串 反 转 ， 其 语法 如 下 : 

string strrev (sting string ): 

参数 string 为 需要 反 转 的 字符 串 。 

在 本 实例 中 ， 通 过 strrev0 函 数 对 上 传 文件 的 名 称 进行 反 转 输 出 ， 并 通过 explode0 函 数 以 “.” 为 分 隔 符 ， 对 
文件 名 称 进行 分 割 ， 然 后 再 次 应 用 strrev0 函 数 对 数组 中 的 第 一 个 元 素 值 进行 返回 输出 ， 获 取 到 的 就 是 上 传 文件 
的 后 级 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 首 先 利 用 POST 方法 接收 文本 框 中 的 信息 ， 然 后 利用 


反 转 函数 将 文本 框 信息 数据 进行 反 转 ， 并 利用 字符 串 拆 分 函数 以 “.” 进 行 分 割 ， 将 分 割 结果 保存 在 数组 中 。 最 
后 将 指定 数据 再 次 反 转 取得 并 输出 上 传 文件 的 后 缀 名 称 ， 其 代码 如 下 : 


php 
if($_POST[sub){ /通过 POST 方式 传递 参数 
$a = strrev($_ POST[text]): / 反 转 字符 串 
$b = explode(".",$a); /以 点 号 分 害 
$e = strrev($b[0]); /I/ 反 转 字符 串 
echo "文件 后 级 为 :.$e": /输出 文件 后 级 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\090 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.64 所 示 。 
国 秘笈 心 ; 


心 法 领悟 090: 知识 扩展 。 
利用 strev0 函 数 检索 字符 串 相对 较 麻烦 ， 可 以 使 用 正则 表达 式 函 数 preg_match() 来 完成 该 功能 。 


力 实例 说 明 
统一 上 传 文件 名 称 的 大 小 写 是 十 分 必要 的 。 例 如 上 传 图 片 文件 img.jpg 和 Img.jpg， 如 果 文 件 名 称 未 经 大 小 

写 统一 ， 则 上 传 时 可 能 不 会 出 现 覆 盖 提 示 。 本 实例 通过 字符 串 函数 strtoupper0 和 strtolower0 实 现 统一 上 传 文件 

名 称 的 大 小 写 ， 运 行 结 果 如 图 2.65 所 示 。 

关键 字 ; snep eenr ees IEEE) 


文件 名 称 自 动 转换 为 
诡 件 名 称 自 动 转换 为 小 写 


2.65 ”统一 上 传 文件 名 称 的 大 小 写 


上 传 


力 关键 技术 


实现 字符 串 的 大 小 写 转换 ， 主 要 通过 strtolower0 和 strtoupper0 函 数 实 现 。 
(1) strtolower0 函 数 
使 用 该 函数 转换 为 小 写 。 


string strtolower ( string str ) 
(2) strtoupper0 函 数 


使 用 该 函数 转换 为 大 写 。 
string strtoupper ( string string ) 
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参数 string 为 需要 转换 的 字符 串 。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 , 当 单 击 ^ 上 传 ?按钮 时 , 分 别 利用 转换 小 写 和 大 写 的 函数 strtolower0 和 strtoupper() 
将 接收 到 的 文本 框 信息 进行 对 应 的 大 小 写 转换 ， 并 输出 转换 结果 ， 其 代码 如 下 : 
<?pl 


if($_POST[sub){ 


// 通 过 POST 方式 传递 参数 


$a = strtoupper($_POST[text]): /| 转换 为 大 写 
echo "文件 名 称 自动 转换 为 大 写 : ".$a."<br>"; /输出 
Sb = strtolower($_POST[text]); /| 转换 为 小 写 
echo "文件 名 称 自 动 转换 为 小 写 :".S$b; /输出 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\091 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.65 所 示 。 
国 秘笈 心 法 


心 法 领悟 091: strtolower0 和 strtoupper() 函 数 的 应 用 范围 。 
在 电子 商务 类 网 站 的 后 台 商品 添加 页 面 中 ， 为 了 使 商品 的 型 号 以 统一 的 规格 显示 ， 
函数 ， 所 以 掌握 这 两 个 函数 是 很 有 必要 的 。 


经 常会 使 用 大 小 写 转换 


实例 092 


趣味 指数 : 友 太 去 友 | 


力 实例 说 明 


在 论坛 文本 框 里 使 用 HTML 标签 是 存在 作用 效果 的 ， 但 是 对 于 论坛 管理 员 来 说 是 不 希望 看 到 的 ， 因 为 它 会 
给 服务 器 造成 压力 。 本 实例 通过 dassm nin 与 HIML 的 转换 ， 运 行 结果 如 图 2.66 所 示 。 


际 是 :人 FF 时 a Mr] : 2010-05:09 Pp 
区 了 了 了 


进行 了 转换 

<table border = '1' > > 标题 ; 经 济 半 小 时 <ytd 改 时 间 : 2010-063 
03< /td> </tr> <tr> < : 经 济 半 小 时 和 了解 中 | 节目 
</td> </tr></tabl 


图 2.66 字符 串 与 HTML 转换 


力 关键 技术 


PHP 中 使 HTML 代码 格式 化 输出 可 以 使 用 函数 htmlentities0 〇 实现 。htmlentities0 函 数 的 语法 如 下 : 
string htmlentities(string string,[int quote_style].[string charset]): 

参数 说 明 : 

string string: 需要 格式 化 输出 的 HTML 代码 。 

int quote_style: 可 选 参 数 ， 一 般 设置 为 ENT_QUOTES。 

string charset: 设置 编码 格式 。 
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力 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 首 先 ， 定 义 字符 串 变量 ， 变 量 内 容 为 一 段 HTML 标签 (创建 表格 的 代码 ) 。 然 
后 ， 利 用 htmlentities0 函 数 将 字符 串 变量 进行 转换 并 输出 转换 结果 ， 其 代码 如 下 : 
2 echo "<h2> 没 有 进行 转换 </h2>"; 
$str = "<table border = '1><tr><td> 标 题 : 经 济 半 小 时 </td><td> 修 改 时 间 : 2010-06-03</td></tr><tr><td> 内 容 : 经 济 半 小 时 ， 了 解 中 国 经 济 最 好 的 


节目 <td></tr><ftable>"; // 定 义 HTML 格式 
echo $str /输出 字符 串 
echo "<h2> 进 行 了 转换 </h2>"; 
echo htmlentities($str, ENT_QUOTES."GB2312")."<br>"; /| 转换 HTML 


Wm. 


(2) 将 该 文件 存储 于 \MR\02\092 文件 夹 下 ， 命 名 为 index.php。 运 行 结 果 如 图 2.66 所 示 。 
力 秘笈 心 法 


心 法 领悟 092: 使 用 格式 化 函数 输出 的 优点 。 
格式 化 输出 HTML 可 以 直接 将 提交 的 源码 输出 并 确保 源码 不 被 解析 ， 从 而 可 以 确保 直接 在 页 面 中 输出 
HTML 标签 ， 而 不 被 解析 。 


m0% | 


力 实例 说 明 


统计 字符 串 长 度 一 般 是 为 了 给 其 他 函数 的 应 用 做 好 铺垫 。 本 实例 通过 strlen0 函 数 获取 帖子 标题 的 长 度 ， 运 
行 结果 如 图 2.67 所 示 。 


标题 。|PHP 编 入 宇和 
内 容 :|PHP 纺 程 宝典 好 


发 布 


本 长度 为 1 个 时 富 
图 2.67 统计 帖子 标题 的 长 度 


力 关键 技术 


strlen() 函 数 用 于 获取 字符 串 的 长 度 ， 其 语法 如 下 : 

int strlen ( string str); 

参数 说 明 : 

str: 指定 字符 串 。 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 发 布 ”按钮 时 ， 利 用 strlen0) 函 数 获取 通过 POST 方式 接收 到 的 数据 长 
度 ， 其 代码 如 下 : 


这 $_POST[sub]){ /通过 POST 方式 传递 参数 
echo "标题 长 度 为 ".strlen($_POST[text)." 个 字 节 "; /获取 字符 串 长 度 
1 


?> 


127 


PHP 开发 实例 大 全 (基础 卷 ) 
(2) 将 该 文件 存储 于 \MR\02\093 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.67 所 示 。 


心 法 领悟 093: 使 用 strlen0 函 数 的 注意 事项 。 
使 用 strlen0 函 数 获取 字符 串 长 度 时 ， 如 果 字符 串 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


A 高 级 | 
实例 094 起 叶枝 让 太太 
图 实例 说 明 


使 用 strlen0 函 数 可 以 统计 论坛 标题 的 长 度 ， 同 样 可 以 对 论坛 中 帖子 的 字 节 数 进行 统计 。 本 实例 通过 strlen0 
函数 对 论坛 中 帖子 的 字 节 数 进行 统计 ， 运 行 结果 如 图 2.68 所 示 。 
| 标题 ，PHP 纺 站 宝典 
ee 


图 2.68 计算 论坛 帖子 的 字 节 数 


图 关键 技术 


本 实例 同样 应 用 strlen0 函 数 统计 字符 串 的 长 度 ， 并 且 应 用 自 定义 函数 对 提交 的 源 代 码 进行 处 理 ， 保 证 源 代 


码 以 原形 式 输出 ， 而 不 会 输出 执行 文件 。 自 定义 函数 的 语法 如 下 : 
function unhtml($content){ 
S$content=htmlspecialchars($content); 
S$content=str_replace(chr(13),"<br>",$content); 
Scontent=str_replace(chr(32),"&nbsp;", $content); 
return trim($content); 


} 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 自 定义 函数 ， 然 后 定义 字符 串 变 量 ， 接 着 应 用 strlen0 函 数 统计 帖子 内 
容 的 字 节 数 ， 并 且 通 过 自 定义 函数 对 帖子 内 容 进行 转换 ， 其 代码 如 下 ;: 
< 
unhtml($content){ 
Scontent=htmlspecialchars($content); 
S$content=str_replace(chr(13)."<br>",$content): 
S$content=str_replace(chr(32),"&nbsp:",$content); 
return trim($content); 
于 PHP 编程 宝典 <br> 内 容 : PHP 编程 宝典 非常 好 ! ": 
?> 
<table border="1" bordercolor="#FF0000" cellspacing="0"><tr><td> 
<?php echo $str:?> 
</td></tr></table> 
<php 
echo "共有 字 节 ".strlen(unhtml($str))." 个 "; 
bo 
(2) 将 该 文件 存储 于 \MR\02\094 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.68 所 示 。 
图 秘 签 心 法 


心 法 领悟 094: 自 定义 函数 unhtml0。 
自 定义 函数 unhtml0 主 要 用 于 对 提交 的 源 代码 进行 处 理 ， 保 证 源 代 码 以 原形 式 输出 ， 而 不 会 输出 执行 文件 。 
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力 实例 说 明 


用 微软 Windows 操作 系统 查找 文件 ， 可 以 使 用 CtrltF 快捷 键 实现 快速 定位 查找 。 本 实例 通过 strpos0 函 数 
模拟 这 一 功能 实现 定位 查找 ， 运 行 结果 如 图 2.69 所 示 。 
| 吉林 省 明日 科技 有 限 公司 是 二 家 以 计算 机 软件 技术 为 核心 型 企业 
[EEC 


计 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核 科技 型 作业 
训 找 内 容 从 6 字 忆 开始 、 字符 虽 长 度 为 8 个 守节 pp xl 


图 2.69 实现 帖子 内 容 定位 查找 


图 关键 技术 
在 PHP 中 实现 特殊 字符 的 查找 和 定位 可 以 通过 stmpos0 函 数 来 实现 ， 函 数 语法 如 下 : 


int strops(string strl ,string str2, [int offset]) 
该 函数 的 作用 是 在 strl 中 查找 sttr2， 并 返回 查找 到 的 位 置 。strpos0 函 数 实现 的 原理 是 比较 整个 要 查找 的 字 
符 串 ， 并 返回 字符 串 str2 第 1 次 出 现 的 位 置 。 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 定 位 查找 ”按钮 时 ， 首 先 定义 一 个 字符 串 变 量 Semail， 然 后 将 接收 到 的 
文本 框 数据 信息 进行 描 红 处 理 ， 最 后 利用 strpos0 函 数 实现 帖子 内 容 的 定位 查找 ， 其 代码 如 下 : 
如 这 $_POST[sub]){ 
Semail = ' 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 ': 
$str=$ POST[tel; 
$strl = "<b style='color:red:>".$str."</b>"; 
echo str_replace($str,$strl,Semail)."<br>"; 
a echo "查找 内 容 从 <b style='color:red;>".strpos($email,$str)."</b> 字 节 开 始 , 字符 串 长 度 为 <b style='color:red;>".strlen($str)."</b> 个 字 
下 
?> 


(2) 将 该 文件 存储 于 \MR\02\095 文件 夹 下 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.69 所 示 。 
国 秘笈 心 法 


心 法 领悟 095: 知识 扩展 。 
strpos0 函 数 一 般 与 strlen0 函 数 联 合 使 用 ， 得 到 的 两 个 结果 相当 于 substr0 函 数 的 两 个 位 置 参数 。 


| 
实例 096 级 | 


a in *| 


力 实例 说 明 


用 户 在 编写 代码 时 也 许 会 在 不 经 意 间 多 输入 了 一 个 或 多 个 空格 ， 使 得 程序 无 论 怎么 调试 都 无 法 正常 运行 。 
本 实例 通过 trim0 函 数 实 现 去 除 帖 子 标题 的 首尾 空格 ， 运 行 结果 如 图 2.70 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


标题 | PEP 提交 
未 去 掉 空格 前 字符 长 度 节 
去 掉 空 格 后 宁 符 长 度 


图 2.70 ”去除 帖子 标题 的 首尾 空格 


图 关键 技术 


在 PHP 中 去 除 字符 串 的 首尾 空格 ， 可 以 使 用 函数 trim0 实 现 。trim0 函 数 的 语法 如 下 : 
string trim(string str); 

参数 说 明 : 

string str: 需要 过 滤 空 格 的 字符 串 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “提交 ”按钮 时 ， 利 用 stlen0 和 tim0 函 数 的 联合 操作 ， 实 现 输出 去 除 首 
尾 空格 前 、 后 的 字符 串 的 长 度 ， 其 代码 如 下 : 

sphp 


if($_POST[sub){ /通过 POST 方式 传递 参数 
echo "未 去 掉 空格 前 字符 长 度 为 ".strlen($_POST[text])." 个 字 节 <br>"; /输出 结果 
echo "去 掉 空格 后 字符 长 度 为 ".strlen(trim($_POST[text])." 个 字 节 "; /输出 结果 
ee } 
(2) 将 该 文件 存储 于 \MR\02\096 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.70 所 示 。 
图 秘笈 心 ; 


心 法 领悟 096: 知识 扩展 。 
PHP 还 提供 有 单纯 去 除 字符 串 左边 或 者 右边 空格 的 函数 ， 详 细 说 明 参 见 实例 083。 


人 i | 
实例 | 
so oa st 
实例 说 明 
货币 数据 不 同 于 整 型 数据 ,其 是 存在 一 定格 式 的 。 本 实例 通过 number_format0 函 数 实现 金额 的 格式 化 输出 ， 


运行 结果 如 图 2.71 所 示 。 
清 输 出 多 入 557 一 
3,587.00 
图 2.71 金额 的 格式 化 输出 
图 关键 技术 


金额 的 格式 化 输出 通过 number format0 函 数 实现 ， 其 语法 及 说 明 如 下 : 

string number format ( float mumber ,int decimals) 

string number_format ( float number, int decimals, string dec_point, string thousands_sep) 

number format(O) 函 数 返 回 参数 number 格式 化 后 的 字符 串 ,该 函数 可 以 有 1 个 、2 个 或 4 个 参数 , 但 不 能 是 
3 个 参数 。 如 果 只 有 1 个 参数 number，number 格式 化 后 会 舍 去 小 数 点 后 的 值 ， 且 以 千 分 位 逗号 “,” 隔 开 ， 如 
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果 有 2 个 参数 , number 格式 化 后 会 到 小 数 点 第 decimals 位 , 且 会 以 每 一 千 喜 号 来 隔 开 ; 如 果 有 4 个 参数 , number 
格式 化 后 会 到 小 数 点 第 decimals 位 ，dec_point 用 来 替代 小 数 点 “.”，thousands_sep 用 来 蔡 代 每 一 千 隔 开 的 逗 
号 4” 。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 当 单 击 “ 格 式 化 ”按钮 时 ， 程 序 自动 将 文本 框 中 的 信息 进行 格式 化 ， 代 码 如 下 : 

2 is PosT[sobD{ /通过 POST 方式 传递 参数 


echo number_format($_POST[text].2): /格式 化 数字 
} 


?> 


(2) 将 该 文件 存储 于 \MR\02\097 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.71 所 示 。 
国 秘笈 心 法 


心 法 领悟 097: 函数 应 用 。 
开发 电子 商务 类 网 站 ， number format0 函 数 出 现 的 频率 是 百分之百 的 ， 所 以 掌握 此 函数 是 十 分 必要 的 。 


实例 098 


趣味 指数 : 址 食 食 三 


力 实例 说 明 


在 PHP 程序 设计 中 ， 经 常用 到 对 日 期 、 时 间 的 格式 化 输出 。 本 实例 通过 date0 函 数 实现 日 期 、 时 间 的 格式 
化 输出 ， 运 行 结 果 如 图 2.72 所 示 。 


显示 当前 9 期 时 间 2010-06-24 13:31:04 
图 2.72 日 期 、 时间 的 格式 化 输出 


图 关键 技术 

本 实例 的 关键 点 是 date0 函 数 的 灵活 运用 ， 详 细 说 明 详 见 实例 035。 
图 设计 过 程 

(1) 创建 PHP 脚本， 当 单 击 “ 显 示 当 前 日 期 、 时 间 ” 按 钮 时 ， 利 用 date0 函 数 根据 传 入 的 指定 的 参数 格式 
实现 格式 化 输出 ， 代 码 如 下 : 


<?php 
了 date_default_timezone_set("Asia/ShangHai"): /设置 时 区 
INS_GET[date] — D{ // 通 过 GET 方式 取得 参数 
echo date("Y-m-d H:i:s"): // 格 式 化 输出 时 间 和 日 期 
} 
?> 
(2) 将 该 文件 存储 于 \MR\02\098 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.72 所 示 。 
国 秘笈 心 法 


心 法 领悟 098: 获取 当地 时 间 。 
获取 当地 时 间 时 一 定 要 首先 设置 时 区 ， 和 否则 PHP 默认 使 用 的 是 英国 伦敦 的 零 时 区 ， 而 在 本 地 使 用 的 是 北京 
时 间 ， 即 东 八 区 的 时 间 。 设 置 时 区 时 ， 可 使 用 date_default_timezone_set("Asia/ShangHai") 语 句 。 
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实例 099 


力 实例 说 明 


在 论坛 程序 中 比较 两 个 帖子 是 否 相同 可 以 屏蔽 重复 帖子 ， 节 省 资源 空间 。 本 实例 通过 字符 串 函数 
similar textO 比 较 两 个 帖子 的 相似 度 ， 运 行 结果 如 图 2.73 所 示 。 


字符 让 1 与 字 行 陪 针 涉 学 节 和 且 ,相似 庆 oo 的 人 
Ca 


图 2.73 ” 比 对 论坛 中 帖子 的 相似 度 


力 关键 技术 
PHP 中 字符 串 相似 度 的 获取 可 以 通过 similar text0 函 数 来 实现 。 其 语法 格式 如 下 ; 


int similar text(sting strl,string str2,[double precent]) 
该 函数 用 于 比较 字符 串 strl 和 字符 串 str2 的 相似 程度 ， 函 数 的 返回 结果 是 字符 串 strl 和 字符 串 str2 的 相同 
字符 的 个 数 ， 而 可 省 参数 precent 的 值 是 这 两 个 参数 的 相似 度 。 


力 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “ 比 较 ”按钮 时 ， 首 先 ， 分 别 获 取 字符 串 1 和 字符 串 2 中 的 数据 ， 然 后 ， 利 
用 字符 串 函数 simlar_text0 实 现 字符 串 相似 度 的 获取 ， 代 码 如 下 : 


<2php 
if($_POST[sub){ /通过 POST 方式 接收 参数 
$a = similar_text($_POST[te],$_POST[tex]); // 判 断 两 个 字符 串 的 相似 度 
if(strlen($_POST[te]) >= strlen($_POST[tex]){ 1/ 计算 百分比 


echo "字符 串 1 与 字符 串 2 有 ".$a." 个 字符 相同 .相似 度 为 ".($a/strlen($_POST[te])*100)."%6"; 
jelsef 
echo "字符 串 1 与 字符 串 2 有 ".$a." 个 字符 相同 .相似 度 为 ".($a/strlen($_POST[tex])*100)."%6"; 


} 


> 


(2) 将 该 文件 存储 于 \MR\02\099 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.73 所 示 。 
国 秘笈 心 法 


心 法 领悟 099: similar textO 函 数 的 原理 。 
similar textO 函 数 的 原理 是 对 应 比较 每 个 字 节 并 根据 结果 计算 百分比 。 


| 
ee 


趣味 指数 : 人 福 食 食 食 


实例 100 


力 实例 说 明 
对 于 电子 商务 网 站 的 用 户 来 说 ， 最 重要 的 就 是 账号 密码 的 安全 性 。 如 果 账 号 密码 未 经 过 加 密 处 理 ， 则 会 大 
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大 增加 安全 隐患 ， 给 非法 用 户 以 可 乘 之 机 。 本 实例 是 通过 字符 串 函数 base64_encode0 和 base64 _decode0 实 现 对 
密码 的 加 密 和 解密 ， 运 行 结果 如 图 2.74 所 示 。 


用 记名 旨 jranming 
证 码 ep@@@e@eeeel 
[L 相 ] 


经 加 密 

用 户 名 :yangitirie 密 码 ca 
经 解密 

用 户 名 ，yangning 密 码 : :3591571301 


图 2.74 对 用 户 注册 的 密码 进行 加 密 和 解密 


力 关键 技术 


对 字符 串 的 base64 编码 可 以 通过 PHP 的 预定 义 函 数 base64_encode0 实 现 ， 其 语法 如 下 : 
string base64_encode(string str) 

该 函数 实现 对 字符 串 str 的 base64 编码 。 

对 已 经 进行 base64 编码 的 字符 串 进行 解码 用 函数 base64_decode0 实 现 ， 其 语法 如 下 : 


string base64_decode(string str) 
该 函数 实现 对 已 经 进行 base64 编码 的 字符 串 进行 解码 。 
图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “提交 ”按钮 时 ， 通 过 字符 串 函 数 base64_encode0 和 base64_decode0 实 现 对 
字符 串 的 加 密 和 解密 ， 代 码 如 下 : 
< 
we if($_POST[sub){ // 通 过 POST 方式 接收 参数 
echo "经 加 密 <hr>"; 
echo "用 户 名 : ".$_POST[text]; 


S$str = base64_encode($_ POST[pwd]): /对 密码 进行 加 密 
echo "密码 : ". $str; 


echo "用 户 名 : ".$_POST[text]; 
echo "密码 : ". base64_decode($str); /对 密码 进行 解密 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\100 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.74 所 示 。 
力 秘笈 心 法 


心 法 领悟 100: 加 密 函 数 的 应 用 。 
base64_encode() 加 密 技术 在 邮件 系统 建设 等 方面 也 得 到 了 广泛 的 应 用 。 


力 实例 说 明 
表单 的 提交 方式 有 两 种 ，GET 方式 和 POST 方式 。GET 方式 属于 明文 地 址 栏 传 参 ， 存 在 安全 隐患 。 本 实例 
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通过 urlencode0 函 数 实现 保护 URL 地 址 中 传递 的 参数 ， 运 行 结 果 如 图 2.75 所 示 。 


当 attp:7/192.168.1 


文件 四 蝙 铝 上 查看 中 er RO Ey 


妨 址 @@) | 罗 http://192. 163.1. 59/mr/02/101/index. php?id+x3D+1 


Eeesns 由 由 | ， 汪 
四 .| © 妥 
图 2.75 保护 URL 地 址 中 传递 的 参数 
力 关键 技术 
PHP 中 字符 串 的 URL 编码 通过 urlencode() 函 数 实现 ， 其 语法 如 下 : 
string urlencode(string str) 
该 函数 实现 对 字符 串 str 的 URL 编码 。 
图 设计 过 程 


(1) 创建 PHP 脚本 ， 定 义 字符 串 变量 ， 将 此 字符 串 变 量 通过 urlencodeO) 函 数 进行 编码 ， 然 后 将 编码 后 的 
字符 串 变量 以 拼接 地 址 栏 参数 的 形式 定义 在 超 链接 中 ， 代 码 如 下 : 


$str="id=1"; // 定 义 字符 串 

$str = urlencode($str); // 对 字符 串 进行 编码 
We 
<a href="index.php?<?php echo $str:?>"> 对 地 址 栏 参 数 加 密 </a> /链接 


(2) 将 该 文件 存储 于 \MR\02\101 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.75 所 示 。 
图 秘笈 心 ; 
心 法 领悟 101: 知识 拓展 。 


经 编码 的 URL 参数 是 可 以 通过 urldecode0 函 数 进行 解码 的 ， 详 细 说 明 详 见 本 实例 。 即 使 不 对 URL 编码 后 
的 参数 进行 解码 ， 同 样 也 可 以 获取 到 传递 的 参数 值 。 


ER 
| 
实 斧 
实例 10 趣味 指教: | 
力 实例 说 明 
本 实例 通过 urldecode0 函 数 解析 URL 地 址 中 传递 的 参数 值 ， 运 行 结果 如 图 2.76 所 示 。 


人 http: //192. 168.1.59/ar/02/10275aEE php 
文件 中 编辑 中 明说 内 ”工具 帮助 0D 
捷 证 加 | 凶 http://lsz 163. 1 5a/ar/oz/lozyindex phpridxz0=xz0l 。 到 国 ] 苇 到 钴 六 辐 


er We 


TT Ov 加 
图 2.76 解析 URL 地 址 中 传递 的 编码 参数 


力 关键 技术 
对 已 经 进行 URL 编码 的 字符 串 进行 解码 使 用 urldecode0 函 数 ， 语 法 如 下 : 


string urldecode ( string str): 
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图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变 量 赋值 。 然 后 ， 将 字符 串 变 量 进行 URL 编码 
处 理 。 最 后 ， 单 击 超 链接 ， 并 将 链接 地 址 用 urldecode0 函 数 解码 ， 代 码 如 下 : 

<?php 


ET // 定 义 字符 串 
$str = urlencode($str); /对 URL 进行 编码 
$strl = urldecode($str); /对 URL 进行 解析 
?> 
<a href="index.php?<?php echo $str1:?>"> 对 地 址 栏 参数 解析 </a> /地 址 栏 传 参 
(2) 将 该 文件 存储 于 \MR\02\102 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.76 所 示 。 


心 法 领悟 102: URL 编码 是 否 可 以 应 用 于 防止 SQL 注入 。 
URL 编码 不 能 有 效 地 防止 SQL 注入 ， 原 因 在 于 URL 编码 可 以 解析 。 


Oe ee —— 
i 趣味 指数 : 二 三 福 全 | 
图 实例 说 明 


实例 043 已 经 向 用 户 介绍 过 “\” 转 义 特殊 字符 的 方法 。 下 面 通过 quotemeta0 函 数 实现 转 义 特殊 字符 ， 运 行 


结果 如 图 2.77 所 示 。 
转换 前 : A 
转换 后 \ 人 AN mingri 
2.77 “特殊 字符 的 转换 
图 关键 技术 
为 了 方便 特殊 字符 的 原样 输出 ，PHP 提供 了 quotemeta0 函 数 ， 其 语法 如 下 : 
string quotemeta(string str) 


该 函数 的 作用 是 在 字符 串 str 中 的 某 些 字符 前 面 加 上 反 斜 杠 “\”， 这 些 特殊 字符 主要 有 “.”、“\”、“+”、 
kp 、 “97 、 We 、 od i 、 Ap a fg 、 wp 、“$”， 其 中 ， 如 果 “$” 后 面 的 字符 与 “$” 共 同 构成 一 
个 合法 的 变量 名 ， 则 “S$” 前 不 加 “\”。 
图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变量 并 将 一 系列 特殊 符号 赋 给 变量 。 然 后 ， 通 过 quotemeta0 函 数 

将 字符 串 变量 进行 转 义 输出 ， 代 码 如 下 : 

<Iphp 


$s="mingri": // 定 义 字符 串 变量 
$str="$.\+*?[]*O$s": // 定 义 字符 串 变 量 
echo" 转 换 前 "$str."<br>"; 
echo "转换 后 :".quotemeta($str); /| 转换 特殊 字符 
?> 
(2) 将 该 文件 存储 于 \MR\02\103 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.77 所 示 。 
力 秘笈 心 法 


心 法 领悟 103: 解决 无 法 原样 输出 字符 的 问题 。 
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在 进行 PHP 项 目 开发 过 程 中 ， 经 常会 遇 到 一 些 无 法 原样 输出 的 字符 ， 解 决 办 法 就 是 通过 转 义 字符 进行 
转 义 。 


高 级 


| 
Se | 
实例 104 起 听 指 数 : 寅 机 页 宽 wx 


力 实例 说 明 


敲 击 计算 机 键盘 上 的 任意 一 个 按键 都 要 经 过 ASCII 码 转换 后 显示 到 屏幕 上 。 本 实例 通过 字符 串 函 数 ord() 
实现 将 字符 转换 为 ASCI 码 ， 运 行 结果 如 图 2.78 所 示 。 


IE 


P 的 ASCII 码 为 ;80 
图 2.78 获取 任意 字符 的 ASCII 码 


图 关键 技术 
PHP 中 获取 字符 的 ASCII 码 应 使 用 ord0 函 数 ， 其 语法 如 下 : 
int ord ( string string); 
该 函数 预期 返回 一 个 整 型 数值 。 
图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “转换 ”按钮 时 ， 通 过 字符 串 函数 ord0 获 取 指定 字符 串 的 ASCII 码 ， 代 码 
如 下 : 
<?php 
这 $_POST[sub]){ // 通 过 POST 方式 传递 参数 
echo "$_ POST[text] 的 ASCII 码 为 : /输出 
echo ord($_POST[text]); WASCI 转 码 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\104 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.78 所 示 。 
图 秘笈 心 法 


心 法 领悟 104: 知识 拓展 。 
像 HTML 标签 “<br>” 等 都 可 以 在 ASCII 码 中 找到 相同 功能 的 ASCII 码 值 。 


高 级 | 
实例 | 
实例 105 趣味 指数 : 友 太 去 二 
图 实例 说 明 

本 实例 通过 字符 串 函数 chr0 实 现 将 ASCII 码 转换 为 字符 ， 运 行 结果 如 图 2.79 所 示 。 


112 转换 


2 的 ASCII 裙 为 


图 2.79 查找 指定 ASCII 码 对 应 的 字符 
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图 关键 技术 

将 ASCI[ 码 转 换 为 字符 可 以 通过 chr0 函 数 实现 ， 其 语法 如 下 : 

该 台数 可 将 ASCI 序数 值 转换 成 对 应 的 字符 ， 与 ord0 函 数 成 对 归 。 
图 设计 过 程 

(1) 创建 PHP 脚本 。 当 单 击 “ 转 换 ” 按 钮 时 ， 首 先 ， 利 用 POST 方法 获取 文本 框 中 传 入 的 数据 信息 ， 然 
SE chr0 函 数 转 换 为 ASCII 码 并 实现 输出 ， 代 码 如 下 : 


if($_POST[sub) { // 通 过 POST 方式 传递 参数 
echo "$_POST[text] 的 ASCI 码 为 :"; /输出 
echo chr($_POST[text]); //ASCII 对 应 的 字符 
网 } 
(2) 将 该 文件 存储 于 \MR\02\105 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.79 所 示 。 


心 法 领悟 105: ASCI 码 的 优点 。 
ASCII 码 在 程序 开发 中 的 使 用 相当 广泛 ， 在 某 些 时 候 将 字符 转换 成 ASCII 码 而 被 系统 识别 ， 既 能 保证 安全 
性 ， 又 能 获取 更 好 的 支持 。 


Es -的 名 称 高 级 | 
xn | ee 
力 实例 说 明 


为 了 使 上 传 文件 的 名 称 不 至 于 与 服务 器 已 有 文件 的 名 称 重 名 ， 合 理 定义 上 传 文件 的 名 称 就 显得 十 分 重要 。 
本 实例 通过 rand0O 函 数 合理 定义 上 传 文件 的 名 称 ， 运 行 结果 如 图 2.80 所 示 。 


园 一 个 贤人 rwms 


亿 择 上 传 文件 : |:\Docunents and Sett 有 HR 


上 传 图 片 大 小 为 (28 


文件 1284345109erestexnlhttp. js 上 传 成 功 ， 大 小 为 : 342 


Cd 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 2.80 合理 定义 上 传 文件 的 名 称 


力 关键 技术 


在 PHP 中 应 用 move_uploaded_file() 函 数 实现 文件 的 上 传 。 但 是 在 执行 文件 上 传 之 前 , 为 了 防止 潜在 的 攻击 
对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 ， 可 以 先 应 用 is_uploaded file0 函 数 判断 指定 的 文件 是 不 是 通过 
HTTP POST 上 传 的 ， 如 果 是 ， 则 返回 TRUE。 
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(1) is_uploaded file0 函 数 
该 函数 用 于 判断 指定 的 文件 是 不 是 通过 HTTP POST 上 传 的 ， 其 语法 如 下 : 


boolis uploaded_ file ( string filename ) 
参数 filename 必须 指定 类 似 于 $_FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 
$ FILES[filename'][name']。 
通过 is_uploaded file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 
件 ， 例 如 /etc/passwd。 
(2) move uploaded file0 函 数 
使 用 该 函数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返 回 TRUE， 否 则 返回 FALSE， 语 法 如 下 : 


bool move_uploaded_file ( string filename, string destination ) 

参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指 文件 上 传 后 保存 的 新 
路 径 和 名 称 。 如 果 参 数 filename 不 是 合法 的 上 传 文件 , 不 会 出 现任 何 操作 ,move_uploaded_file() 将 返回 FALSE; 
如 果 参 数 filename 是 合法 的 上 传 文件 ， 但 由 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ，move_uploaded file0 
将 返回 FALSE， 此 外 还 会 发 出 一 条 警告 。 

(3) rand0 函 数 

使 用 该 函数 生成 的 随机 整数 作为 上 传 文件 的 新 名 称 。 


图 设计 过 程 
创建 index.php 文件 ,添加 表单 ,设置 文件 域 .提交 按钮 , 使 用 POST 方法 , 设置 enctype="multipart/form-data"， 
通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完成 图 片上 传 ， 其 代码 如 下 : 


<2php 
这 !empty($_FILES[up_picture][name])){ // 判 断 上 传 内 容 是 否 为 空 
if($_FILES['up_picture']['error >0){ // 判 断 文 件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错 误 :"; 
switch($_FILES[up_picture][error]){ 
case 1: 
ccho "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
ase 3: 
echo "上 传 文件 不 全 ": 
break: 
case 4: 
echo "没有 上 传 文件 "; 
break: 
} 
Jelse{ 
(tis_dir("./upfile/") { // 判 断 指定 目录 是 否 存 在 
mkdir("./upfile/"); // 创 建 目录 
攻 
S$path= upfile/rand0.$_FILES[up_picture][name]: /定义 文件 名 称 和 存储 位 置 
ifis_uploaded_file($_FILES[wp_picture [tmp_name]){ // 是 不 是 HITP POST 上 传 
这 Imove_uploaded_file($_FILES[mp_picture'][tmp_name].$pathb)){ /执行 上 传 
echo "上 传 失 败 ": 
jslse{ 


echo "文件 "time0.$_FILES[up_picture][mame']." 上 传 成 功 ， 大 小 为 : "$_FILES[up_picture]['size']; 
。 
Jelse{ 
echo "上 传 文件 ".$_FILES['up_pictute"][name"]." 不 合法 ! "; 
} 
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心 法 领悟 106: 上 传 文件 的 命名 问题 。 
上 传 文件 如 果 和 已 有 文件 重 名 ， 文 件 可 能 会 相互 苦 换 ， 给 网 站 造成 损失 。 所 以 确保 上 传 文件 名 称 的 唯一 性 
是 非常 必要 的 ， 也 可 以 通过 time0 时 间 戳 来 定义 上 传 文件 的 名 称 。 


注册 密码 进行 加 密 高 级 | 


趣味 指数 : 依依 请 坪 | 


实例 107 


力 实例 说 明 


图 2.81 通过 异 或 方式 对 用 户 注册 密码 进行 加 密 


图 关键 技术 


通过 异 或 方式 对 字符 串 加 密 的 原理 : 当 一 个 字符 串 A 与 另 一 个 字符 串 B 进行 异 或 运算 后 会 产生 一 个 字符 
串 CC。 


力 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变量 赋值 。 然 后 ， 通 过 异 或 方式 对 字符 串 变量 
进行 加 密 并 输出 加 密 结果 ， 代 码 如 下 : 

< 


php 
if($_POST[sub){ /通过 POST 方式 传递 参数 

Sstr = "0123456798"; /定义 字符 串 
echo "用 户 名 : ".$_POST[text]."<br>"; 
echo " 密 &nbsp:&nbsp: 码 : ".($_POST[pwd]^$str): // 异 或 加 密 

> 2 

(2) 将 该 文件 存储 于 \MR\02\107 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.81 所 示 。 

力 秘笈 心 法 


心 法 领悟 107: 比较 异 或 方式 与 md5 加 密 技术 。 
PHP 中 对 字符 串 加 密 的 方式 有 很 多 种 ， 如 md5 加 密 等 。 异 或 方式 与 md5 加 密 方式 的 本 质 区 别 是 mds 加 密 
后 不 能 解密 ， 异 或 方式 可 以 。 相 对 而 言 ，md5 加 密 更 加 安全 。 


高 级 | 


实例 108 趣味 指数 : loboiod 


力 实例 说 明 
网 站 的 国际 化 已 经 不 是 一 个 炙手可热 的 话题 ， 但 是 由 于 地 区 差异 ， 在 使 用 英文 填写 注册 信息 时 ， 首 字母 的 
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大 小 写 往往 得 不 到 统一 。 本 实例 利用 ucfirst0 函 数 实现 将 英文 注册 用 户 的 首 字母 统一 为 大 写 ,运行 结果 如 图 2.82 
所 示 。 


图 2.82 统一 英文 注册 用 户 首 字母 的 大 小 写 


力 关键 技术 


在 PHP 开发 中 , 定义 首 字母 大 写 的 方法 有 很 多 , 但 是 所 有 的 方法 都 没有 使 用 PHP 预定 义 函数 ucfirst0 简 单 。 
ucfirst0 函 数 的 语法 如 下 : 

string ucfirst ( string str ); 

参数 说 明 : 

string str: 定义 字符 串 。 


图 设计 过 程 

(1) 创建 PHP 脚本 。 当 单 击 “ 提 交 ” 按 钮 时 ， 首 先 利用 POST(O 方 法 获取 从 文本 框 传递 进来 的 数据 ， 然 后 
将 获取 的 数据 经 ucfirst0 函 数 转换 首 字母 大 写 ， 最 后 输出 经 转换 后 的 数据 ， 代 码 如 下 : 

<?php 


这 $_POST[sub]){ // 通 过 POST 方式 传递 参数 
$a=$_POST[text]: // 接 收 参数 
echo " 首 字母 统一 为 大 写 :"; 
echo ucfirst($a): /转换 单词 首 字母 
党 } 
(2) 将 该 文件 存储 于 \MR\02\108 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.82 所 示 。 
图 秘笈 心 法 


心 法 领悟 108: 知识 拓展 。 

实现 字符 串 首 字母 大 小 写 转换 还 可 以 通过 转 码 来 完成 。 首 先 利用 substr0 函 数 提取 出 字符 串 的 首 字母 ,之 后 
利用 ord0 函 数 获取 该 字母 的 ASCII 码 , 再 根据 大 小 写字 母 之 间 相 差 32 来 实现 大 小 写字 母 之 间 的 ASCII 码 转换 ， 
最 后 利用 chr0 函 数 将 转变 后 的 ASCII 码 转变 为 字母 即 可 。 
转换 高 级 | 


起 味 指数 : 宙 宙 页 页 


实例 109 


力 实例 说 明 
来 看 两 个 变量 $a = 123; 和 $a = '123';。 前 者 是 整 型 变量 ， 后 者 是 字符 型 变量 。 本 实例 利用 函数 使 字符 型 变量 
转换 为 整 型 变量 ， 整 型 变量 转换 为 字符 型 变量 ， 运 行 结果 如 图 2.83 所 示 。 


转换 前 类 型 为 :string 出 :123 
转换 后 输出 :123， 为 :integer 
转 光 前 类 型 为 “iiteger， 原 字 竺 素 输 出 : 123 


多 后 闪 出 : 123) 航 后 将 为 :string 
图 2.83 字符 串 与 数字 之 间 的 转换 
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图 关键 技术 
在 PHP 中 ， 将 数字 转换 为 字符 串 可 以 通过 strval0 函 数 实现 ， 其 语法 如 下 : 
string strval ( mixed var) 
该 函数 用 于 返回 变量 var 对 应 的 string 值 。 
图 设计 过 程 
(1) 首先 创建 脚本 文件 ， 定 义 字符 串 变量 并 将 数值 型 字符 串 赋 给 变量 ,然后 通过 strval0 函 数 转换 数据 ， 代 
码 如 下 : 
<?php 
S$str = "123"; // 定 义 字 符 串 
echo "转换 前 类 型 为 :".gettype($str); // 取 得 当前 数据 类 型 
echo "， 原 字符 串 输出 : ".$str; 
echo "<br>"; 
echo "转换 后 输出 : ".intval($str); // 将 字符 串 转换 为 整 型 
echo "， 转 换 后 类 型 为 :".gettype(intval($stn)); // 取 得 转换 后 的 数据 类 型 
echo "<hr>"; 
Sint = 123; // 定 义 整 型 变量 
echo "转换 前 类 型 为 ，".gettype(S$int); // 取 得 当前 类 型 
echo "， 原 字符 串 输出 :".$int; 
echo "<br>"; 
echo "转换 后 输出 : ".strval(Sint); /转换 为 字符 串 


echo "， 转 换 后 类 型 为 ，".gettype(strval(Sint); /输出 转换 后 的 数据 类 型 
Cy 将 该 文件 存储 于 \MR\02\109 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.83 所 示 。 
秘 敌 心 > 

心 法 领悟 109: 简 述 strval0 和 intval0 函 数 。 

strval0 和 intval0 函 数 在 实现 功能 上 与 强制 类 型 转换 机 制 相同 。 


, 和 i 0 | 
趣味 指数 : obokolodl| 
图 实例 说 明 


字符 串 匹 配 查 找 的 方法 有 很 多 ， 下 面 来 了 解 如 何 用 正则 表达 式 对 字符 串 进行 匹配 查找 。 本 实例 通过 数组 函 
数 和 正则 表达 式 函 数 preg_match() 来 实现 字符 串 的 匹配 查找 ， 运 行 结果 如 图 2.84 所 示 。 


f 


图 2.84 利用 正则 表达 式 实 现 字符 串 的 匹配 查找 


图 关键 技术 


灵活 运用 正则 表达 式 函 数 是 本 实例 的 关键 。preg_match0 函 数 用 于 匹配 指定 字符 串 ， 一 般 情况 下 ， 会 与 让 
条 件 语句 协同 使 用 ， 其 语法 如 下 : 


int preg_match ( string pattem. string subject [. array matches] ) 


函数 功能 : 在 字符 串 subject 中 匹配 表达 式 pattem。 函 数 返 回 匹 配 的 次 数 。 如 果 有 数组 matches， 那 么 每 次 
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匹配 的 结果 将 被 存储 到 数组 matches 中 。 该 函数 在 匹配 成 功 后 就 停止 继续 查找 ， 其 返回 值 是 0 或 1。 
力 设计 过 程 
(1) 创建 PHP 脚本 。 首 先 ， 定 义 数组 变量 $a 并 为 $a 赋值 。 然 后 ， 利 用 foreach 语句 遍历 数组 以 便 取 得 key 


值 和 value 值 。 最 后 ， 利 用 正则 表达 式 函 数 preg_match0 将 通过 POST 方法 传递 进来 的 数据 进行 匹配 ， 匹 配 成 功 
则 输出 对 应 数组 的 value 值 ， 代 码 如 下 : 


<?php 
$a = array('mrsoft',' 明 日 mr 科技 ,www.mrsoft.com'); // 定 义 数组 
foreach($a as $key => $value){ //foreach 循环 遍历 数组 
$a=$_POST[te]:; 
iflpreg_match("/$al",Svalue){ /正则 表达 式 匹 配 
echo $value; 
echo "<br>"; 


8 
} 


?> 
(2) 将 该 文件 存储 于 \MR\02\110 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.84 所 示 。 
秘笈 心 ; 
心 法 领悟 110: SQL 语句 的 匹配 问题 。 
PHP 项 目 开 发 过 程 中 可 以 利用 SQL 语句 中 的 关键 字 like， 对 数据 库 中 的 内 容 进 行 匹 配 查找 ， 其 实现 的 是 数 
据 库 中 数据 的 模糊 查询 。 


实例 111 


趣味 指数 : 食 食 食 食 | 
| 


力 实例 说 明 


IP 地 址 是 互联 网 身份 的 象征 ， 通 过 IP 地 址 可 以 得 到 用 户 的 相关 信息 。 本 实例 通过 正则 表达 式 验证 IP 地 址 
是 否 合法 ， 然 后 实现 瑟 地 址 的 格式 转换 ， 进 而 获取 人 P 地 址 所 在 地 ， 运 行 结 果 如 图 2.85 所 示 。 


[En 
对 ia4548455 


2.85 利用 卫 地 址 查找 主机 所 在 地 


力 关键 技术 


首先 需要 验证 输入 的 IP 地 址 是 否 合 法 ， 如 果 合 法 ， 再 将 其 转换 为 对 应 的 数值 。 验 证 IP 地 址 是 否 合法 可 以 
通过 正则 表达 式 实现 。 

卫 地 址 使 用 4 位 地 址 定位 设备 ， 它 采用 点 分 十 进 制 数 的 格式 “xxx.xxx.xxx.xxx”， 例 如 192.168.1.66。 因 此 ， 
验证 瑟 地 址 是 否 合法 的 正则 表达 式 如 下 : 

JapGd Gd Ga/ 

将 人 P 地 址 转换 为 对 应 的 数值 可 以 应 用 以 下 公式 实现 : 


P14255+2554255+P242554255+P3+255+P441 
在 上 面 的 公式 中 ，P1 代表 人 P 地 址 第 1 段 的 数值 ，P2 代表 人 P 地址 第 2 段 的 数值 ，P3 代表 人 P 地 址 第 3 段 的 
数值 ，P4 代表 人 P 地 址 第 4 段 的 数值 。 
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图 设计 过 程 
(1) 编写 JavaScript 脚本 ， 定 义 deal0 方 法 验证 用 户 提 交 的 IP 地址 格式 是 否 正确 ， 定 义 convert0 方 法 将 全 
地 址 转换 为 对 应 数值 ， 该 方法 只 有 一 个 参数 p， 用 于 指定 了 P 地 址 ， 返 回 值 为 PP 地 址 对 应 的 数值 ， 代 码 如 下 : 


<script language="javascript"> 
function deal(myform){ // 自 定义 函数 
var ip=form] ip value: // 定 义 变量 
objExp=/(\d+).(0d+).0d+).0d+)/: /正则 表达 式 
ifip 一 ""{ // 条 件 判 断 


alert(" 请 输入 卫 地 址 !"):forml .ip focusO:retumn: 
} 
if(objExp.test(ip){ 


jelsef 
alert(" 您 输入 的 他 地 址 不 合法 !:forml.ip focusO:retum: 


ipNum.value=convert(ip); 


function convert(ip){ // 自 定义 函数 
ip=ip.split("."); 
vip=ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1; /转换 程式 
retum vip; // 返 回 值 
} 
</script> 


(2) 创建 index.php 文件 ， 通 过 form 表单 提交 要 验证 的 IP 地 址 ， 调 用 JavaScript 脚本 中 的 方法 验证 IP 地 
址 格式 并 完成 格式 的 转换 操作 。 


力 秘笈 心 法 
心 法 领悟 111: 使 用 8$_SERVER["REMOTE ADDR"] 的 注意 事项 。 
在 PHP 中 ， 可 以 通过 $_ SERVER["REMOTE_ ADDR"] 获 取 客户 机 的 卫 地 址 ， 但 并 不 能 判断 该 PP 地 址 的 所 
在 地 。 如 果 要 判断 他 地 址 的 所 在 地 ， 就 必须 对 其 格式 进行 转换 。 
寺中 文字 符 囊 截取 时 出 现 乱码 的 问题 高 级 | 
| 


趣味 指数 : 依依 依依 | 


实例 112 


力 实例 说 明 


使 用 substr0 函 数 是 按 字 节 截取 字符 串 ， 在 截取 中 文字 符 串 时 ， 由 于 一 个 汉字 由 两 个 字符 组 成 ， 如 果 只 截 
取 1 个 字符 就 会 出 现 乱 码 。 本 实例 使 用 自 定义 函数 解决 对 中 文字 符 串 截取 时 的 乱码 问题 ， 运 行 结果 如 图 2.86 
所 示 。 


吉林 省 明日 科技 帮 限 公 以 计算 轴 铭 件 捷 术 为 榨 必 型 企业 
[0 中 字 . |] 
吉林 省 明日 科技 有 有 阳 公 司 ;| + on [4 #4 


图 2.86 解决 用 substr0 函 数 对 中 文字 符 串 截取 时 的 乱码 


国 关键 技术 


对 中 文字 符 串 的 截取 虽说 是 通过 自 定义 函数 来 完成 的 ， 但 是 其 根本 还 是 应 用 substr0 函 数 ， 只 是 在 进行 字符 
串 截 取 时 ， 对 字符 串 的 类 型 进行 了 判断 。 
对 截取 字符 串 中 首 个 字 节 的 ASCII 序数 值 进行 判断 ， 如 果 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 ， 那 么 在 
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应 用 substr0 函 数 进行 截取 时 ， 就 以 2 个 字 节 为 单位 ; 如 果 ASCII 序数 值 小 于 0xa0， 则 表示 为 英文 字符 串 ， 那 么 
在 应 用 substr0 函 数 进行 截取 时 ， 就 以 1 个 字 节 为 单位 。 这 样 将 中 文字 符 串 和 英文 字符 串 分 隔 进行 截取 就 避免 了 
出 现 乱码 的 问题 。 


自 定义 函数 msubstr0 的 语法 如 下 : 

function msubstr($str, $start, $len) { /JSstr 指 的 是 字符 串 ，Sstart 指 的 是 字符 串 的 起 始 位置 ，S$len 指 的 是 长 度 
S$strlen = $start + Slen; /用 $strlen 存储 字符 串 的 总 长 度 ( 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i = 0; $i < $strlen; $i++) { // 通 过 for 循环 语句 ， 循 环 读 取 字符 串 


于 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { ”// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr = substr ( $str, Si 2 ); /每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 
Si++t; /变量 自 加 1 

jelse{ // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr .= substr ( $str, $i, 1 ); 

和 


} 
return $tmpstr; /| 输出 字符 串 


} 

其 中 ,参数 $str 是 指定 被 截取 的 字符 串 ; 参 数 $start 是 截取 的 开始 位 置 ;参数 $len 是 截取 的 长 度 。 返 回 值 Stmpstr 
是 截取 后 的 字符 串 。 

设计 过 程 

创建 index.php 文件 ， 定 义 msubstr0 函 数 ， 对 中 文字 符 串 进行 截取 。 创 建 form 表单 ， 提 交 字 符 串 截取 的 开 
始 位 置 和 长 度 ， 然 后 调用 msubstr0 函 数 对 字符 串 进行 截取 并 且 输 出 截取 结果 ， 代 码 如 下 : 


<?php 

function msubstr($str, $start, Slen) { /WSstr 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 是 长 度 
S$strlen = $start + Slen; // 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i = 0; $i < $strlen; Si++) { /通过 for 循环 语句 ， 循 环 读 取 字 符 串 


让 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr .= substr ( $str, $i, 2 ); /每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
Si++ /变量 自 加 1 

j else{ /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr .= substr ( $str, $i, 1 ); 

} 


} 
return $tmpstr /输出 字符 串 


} 

$string=" 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 ": 
$str=msubstr($string,$_POST[te].$_POST[tx]): 

echo $str: 

> 


图 秘笈 心 法 


心 法 领悟 112: 利用 函数 截取 中 文字 符 串 的 注意 事项 。 
使 用 substr0 函 数 截 取 中 文字 符 串 时 最 好 首先 定义 算法 ， 以 免 截 取 半 个 中 文 文字 而 出 现 乱 码 。 


实例 113 趣味 指数 : 娘娘 太太 
看 实例 说 明 


本 实例 是 通过 PHP 5.0 中 的 新 型 字符 串 实现 字符 串 与 HIML 标记 的 相互 转换 ， 运 行 结果 如 图 2.87 所 示 。 
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图 2.87 字符 串 与 HTML 标记 的 相互 转换 


图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 


图 设计 过 程 


创建 index.php 文件 ， 利 用 PHP 5.0 新 型 字符 串 将 HTML 标记 封装 到 PHP 的 变量 中 ， 并 且 输 出 PHP 变量 的 


S$str=<<<mark // 新 型 字符 串 格式 
<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 字 符 串 与 HTML 标记 相互 转换 </title> 

</head> 


<body background="../image/1.jpe" style="font-size:16px; color:blue; font-family:' 微 软 雅 黑 "><table border="1"><tr><td> 
<form action="" method="post"> 
用 户 名 : <input type="text" name="test" size="15" /><br> 
密 &nbsp:&nbsp:&nbsp: 码 : <input type="password" name="pwd" size="15" /><br> 
<input type="submit" name="sub" value=" 提 交 " /> 
</form></td></tr></table> 
</body> 
<html> 
mark:; // 新 型 字符 串 结束 符 
S Sstr: 


| | 秘 签 心 法 


心 法 领悟 113: 新 型 字符 串 的 应 用 范围 。 
新 型 字符 串 被 广泛 应 用 在 含有 较 多 HTML 标记 的 PHP 编码 中 。 


字符 囊 输出 XML 数据 高 级 | 


力 实例 说 明 
本 实例 通过 PHP 5.0 新 型 字符 串 输出 XML 格式 的 数据 ， 运 行 结果 如 图 2.88 所 示 。 


包 运 用 PPS 新 型 字符 审 输出 TEL 数据 一 Wicroseft IAAEGEG 
EECTETOE WD 
瑞士 包 | hp//192 169.1.59/or/02/114index ph 本 加 革 到 | 三 病 可 


httpyfwrwrw mingrisoft com 吉林 省 明日 科技 有 限 公司 
httpyfwrww mingrisoft com httpyfwww mrbccdcom 明日 科技 编程 词 
典 重 者 出 击 ， 隆 重 上 市 ! 2008-08-08 


EE | | | © 人 SW 


2.88 PHP 5.0 新 型 字符 串 输出 XML 格式 的 数据 
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图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 
图 设计 过 程 
创建 index.php 文件 ， 定 义 PHP 5.0 新 型 字符 串 ， 通 过 其 输出 XML 格式 的 数据 ， 代 码 如 下 : 


<?php 
S$str=<<<mark 
<?xml version="1.0" encoding="utf8"?> 
<rss xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:dc="http://purl.org/de/elements/1.1/" 
xmilns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0"> 
<channel> 
<title> 明 日 科技 </title> 
<link>http://www.mingrisoft.com</link> 
<description> 吉 林 省 明日 科技 有 限 公司 </description> 
<de:creator>http://www.mingrisoft.com</de:creator> 
<item> 
<title> 编 程 词典 </title> 
<link>http://www.mrbeed.com</link: 
<description> 明 站 科技 六 各 亲 典 重 闪 出 击 ， 隆重 上 市 ! </description> 
<pubDate>2008-08-08</pubDate> 
litem> 
人 


Se Se 
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心 法 领悟 114: 使 用 新 型 字符 串 的 优点 。 
在 PHP 5.0 之 前 的 开发 中 ， 想 要 在 PHP 中 输出 一 些 HTML 标记 是 通过 echo 语句 一 行 一 行 输出 的 ， 这 无 疑 
是 一 件 非常 头痛 的 事 。 现 在 PHP 提供 了 新 型 字符 串 ， 相 关 的 问题 就 可 迎刃而解 了 。 


实例 115 趣味 指数 : tool 


力 实例 说 明 


判断 一 个 字符 串 中 是 否 含有 另 一 个 字符 串 的 方法 有 很 多 ， 例 如 ， 正 则 表达 式 等 。 本 实例 通过 stristr0 函 数 判 
断 字符 串 中 是 否 存在 指定 子 串 ， 运 行 结果 如 图 2.89 所 示 。 


Hello WorldU 
归 


图 2.89 字符 串 中 不 存在 子 串 


图 关键 技术 


判断 一 个 字符 串 是 不 是 另 一 个 字符 串 的 子 串 可 通过 stristr0 函 数 实现 ， 其 语法 如 下 : 
string stristr ( string haystack, string needle ): 
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该 函数 获取 指定 字符 串 〈A) 在 另 一 个 字符 串 〈B) 中 首次 出 现 的 位 置 到 字符 串 〈B) 末尾 的 所 有 字符 串 。 
参数 haystack 指定 查找 的 字符 串 ， 参 数 needle 指定 查找 的 对 象 。 

该 函数 如 果 执 行 成 功 则 返回 剩余 的 字符 串 ， 否 则 将 返回 FALSE。 
图 设计 过 程 

创建 index.php 文件 ， 定 义 字符 串 变量 ， 将 该 变量 与 通过 POST( 方 法 传递 进来 的 数据 利用 stristr0 函 数 进行 
比较 并 输出 结果 ， 代 码 如 下 : 

<2pl 


hp 
$a = "Hello World !1"; /定义 字符 串 
echo $a; /输出 字符 串 
echo "<form action="method=-'po /输出 表单 


echo "<input type=text 人 
echo "<input type='submit name='sub' value=' 提 交 '>"; 


echo "</form>"; 
if$_POST[sub]){f /通过 POST 方式 传递 参数 
if(stristr($a, $_ POST[text]) 二 ""){ // 判 断 是 否 存在 子 串 
echo "<script>alert( 文 本 存在 指定 子 串 ):</script>"; // 提 示 
Jelse{ 
echo "<script>alert(' 文 本 不 存在 指定 子 串 );</script>"; /提示 
?> 
图 秘笈 心 ; 


心 法 领悟 115:; 知识 扩展 。 
stristrO 函 数 还 可 以 作为 分 割 函数 的 一 部 分 ， 从 符合 条 件 的 字符 串 开始 截取 ， 一 直到 文件 末尾 。 该 函数 不 区 
分 大 小 写 ， 如 果 要 在 区 分 字母 大 小 写 的 情况 下 进行 搜索 ， 可 以 应 用 strstr0 函 数 。 


2.9 正则 表达 式 


正则 表达 式 是 一 种 描述 字符 串 结构 模式 的 形式 化 表达 方法 ， 是 一 个 强大 、 便 捷 、 高 效 的 文本 处 理工 具 ， 可 
用 于 验证 用 户 输入 的 数据 和 检索 大 量 的 文本 。 在 PHP 中 , 表达 式 应 用 最 好 的 体现 是 对 表单 提交 的 数据 进行 验证 ， 
判断 是 否 合理 、 合 法 。 


力 实例 说 明 


表单 注册 时 往往 要 求 用 户 书写 座机 电话 号 码 ， 而 座机 电话 号 码 是 由 11 位 或 12 位 数字 组 成 的 ， 所 以 一 定 要 
对 电话 号 码 的 位 数 和 格式 进行 限制 .本 实例 通过 正则 表达 式 和 正则 表达 式 函 数 preg_match0) 实 现 对 电话 号 码 格式 
的 验证 ， 运 行 结果 如 图 2.90 所 示 。 


趣味 指数 : 食 食 三 食 


[aaa | 


图 2.90 验证 电话 号 码 的 格式 是 否 正确 
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图 关键 技术 


(1) preg_match0: 进行 正则 表达 式 匹配 。 
int preg_match ( string pattem, string subject [, amray matches [, int lags]]); 

(2) 正则 表达 式 ， 固定 总 位 数 为 11 位 或 12 位 的 座机 电话 。 
10d{3}-)0d{8DSI0d{4}-)0d{7 Ds/; 


力 设计 过 程 
创建 index.php 文件 ， 通 过 正则 表达 式 函数 对 输入 文本 框 的 电话 号 码 进行 验证 ， 并 输出 相关 提示 ， 其 代码 


如 下 : 
ifs_POST[sub]){ 
if(preg_match("/(\d{3}-)(d{8})$SI(d{4}-)0d{7})$/",s_POST[textD){ // 正 则 表达 式 验证 
include("ine php"); 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); /调用 自 定义 函数 输出 提示 信息 
Jelse{ 
C include("ine php"); 
show_error(" 信 息 提示 "," 格 式 错误 ","index.php"); /调用 自 定义 函数 输出 提示 信息 
} 
} 
?> 
国 秘笈 心 法 


心 法 领悟 116: 使 用 正则 表达 式 的 注意 事项 。 
正则 表达 式 “/(\d{3}-)Qd{8))$IQNd{4}-)(\qd{7})$/” 是 根据 新 式 电话 号 码 设置 的 ， 老 式 的 座机 电话 是 由 10 位 数 


字 组 成 的 。 


实例 117 


力 实例 说 明 


互联 网 发 展 到 今天 , 几乎 所 有 的 Web 爱好 者 都 有 自己 的 E-mail 地 址 ,无 论 申请 的 是 126 邮箱 还 是 163 邮箱 ， 


E-mail 地 址 的 格式 是 固定 的 。 本 实例 通过 preg_matchO 正 则 匹配 函数 和 正则 表达 式 验证 E-mail 地 址 格式 是 否 正 


确 ， 运 行 结果 如 图 2.91 所 示 。 


2.91 ”验证 E-mail 地 址 格式 是 否 正确 


图 关键 技术 


(1) preg_matchO 函 数 : 进行 正则 表达 式 匹 配 ， 详 细 参 数 参 见 实例 110。 


(2) 了 


E 则 表达 式 : 对 E-mail 地 址 进行 验证 。 


Nr(E Tt @ rt J (Jt): 
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// 包 含 信息 提示 页 


趣味 指数 : 请 请 请 育 | 
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力 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 ,通过 正则 表达 式 函 数 验证 文本 框 传 入 的 信息 并 输出 对 应 提示 ， 
其 代码 如 下 : 
if(s_ POST[subD){ 
require_once("inc.php"); // 包 含 信息 提示 页 
if(preg_match("/N\w+([-+,] w+)*@\wt([- J wr) * wt([-. J )*/",trim($_POST[ text D){ // 正 则 表达 式 验证 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); /输出 提示 
Jelse{ 
show_error(" 信 息 提示 "," 格 式 不 正确 "."index.php"); /输出 提示 
} 
a 
?> 
秘笈 心 法 


心 法 领悟 117: PHP 支持 的 两 种 正则 表达 式 函 数 库 。 
PHP 支持 两 种 正则 表达 式 函 数 库 ， 一 种 是 正则 表达 式 函 数 库 (POSIX 扩展 ) ， 另 外 一 种 是 正则 表达 式 函 数 
库 (Perl 兼容 ) 。 在 性 能 上 ，Perl 兼容 正则 表达 式 速度 更 快 一 些 。 


高 级 | 
起 味 指数 : 请 塘 庚 庚 


实例 118 


图 实例 说 明 


IP 地 址 是 Web 用 户 可 以 访问 互联 网 的 身份 凭证 。 每 一 个 IP 地 址 相对 其 他 用 户 的 他 都 是 独立 的 。 本 实例 通 
过 正则 表达 式 函 数 preg_match0 和 正则 表达 式 对 IP 地 址 进行 验证 ， 运 行 结果 如 图 2.92 所 示 。 


2.92 ”验证 人 P 地 址 是 否 有 效 


图 关键 技术 


(1) preg_match_ all0 函 数 ， 在 字符 串 subject 中 匹配 表达 式 pattem， 函 数 返 回 匹 配 的 次 数 。 如 果 有 数组 
matches， 那 么 每 次 匹配 的 结果 将 被 存储 到 数组 matches 中 ， 其 语法 如 下 : 


int preg_match_all ( string pattem, string subject [, array matches] ) 
(2) 正则 表达 式 : 对 人 P 地 址 进行 验证 。 


"Ndr\dt\dr\\d+/":; 


图 设计 过 程 


(1) 创建 index.php 文件 ， 通 过 form 表单 提交 IP 地 址 ， 当 单 击 “ 验 证 ”按钮 时 ， 通 过 正则 表达 式 函 数 验 
证 焉 地址 ， 并 且 返 回 验证 结果 ， 其 代码 如 下 : 


<2php 
if($_POST['subD){ 
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Tequire_once("inc.php"); 
if(preg_match("/N\d+\\d+\\d+\\d+/",trim($_POST['text])){ 
show_error(" 信 息 提示 "." 格 式 正确 ","index.php"); 
yelse{ 
show_error(" 信 息 提 示 "," 格 式 不 正确 ","index.php"); 
} 
} 


(02) 创建 inc.php 文件 ， 定 义 方法 show_error0， 根 据 传递 的 参数 值 定义 返回 的 错误 信息 。 
国 秘笈 心 法 
心 法 领悟 118: IP 地 址 是 什么 。 
Internet 为 每 一 个 主机 分 配 唯一 的 一 个 32 位 地 址 ， 该 地 址 称 为 IP 地 址 ， 也 称 网 际 地 址 。JP 地 址 由 4 个 数组 


成 ， 每 个 数 取 值 范围 为 0-255， 每 两 个 数 之 间 用 “.” 分 隔 。 所 以 IP 地 址 的 格式 是 固定 的 ， 正 则 表达 式 
“Ad+\d+\dt\.\d+/” 可 以 验证 所 有 IP 地 址 。 


趣味 指数 : Po 


实例 119 


实例 说 明 


统计 关键 字 的 查询 结果 的 方法 有 很 多 ， 本 实例 通过 正则 表达 式 函 数 split0 和 count0 实 现 统计 关键 字 ， 运 行 
结果 如 图 2.93 所 示 。 


PHP 作 为 全 球 最 普及 、 应 用 最 | 
知名 互联 网 公司 Google、Yal 
输出 关键 字 P- 志 

of /34 4 BA MN 3 +41 


图 2.93 ”统计 关键 字 的 查询 结果 


图 关键 技术 


splitO 函 数 : 用 正则 表达 式 将 字符 串 分 割 到 数组 中 。 

array split ( string pattern, string string [, int limit]); 

该 函数 返回 一 个 字符 串 数 组 ， 每 个 单元 为 string 经 区 分 大 小 写 的 正则 表达 式 pattern 作为 边界 分 割 出 的 子 
串 。 如 果 设 定 了 limit， 则 返回 的 数组 最 多 包含 limit 个 单元 ， 而 其 中 最 后 一 个 单元 包含 string 中 剩余 的 所 有 部 
分 。 如 果 出 错 ， 则 split0 函 数 返 回 FALSE。 


力 设计 过 程 
创建 index.php 文件 。 首 先 ， 定 义 字 符 串 变 量 $str 并 为 $str 赋值 。 然 后 ， 利 用 split0 函 数 检索 字符 p 在 $str 中 
的 出 现 次 数 ， 并 输出 检索 的 结果 ， 其 代码 如 下 : 


<2php 
/定义 字符 串 变量 
$str = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知 名 互联 网 公司 
Google、Yahoo、eBay 和 中 国 知名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采 用 PHP 技术 ! "; 
S$b = split("P",Sstr): /使 用 split0 函 数 进行 分 割 
echo "<h4 style =red>"; 
echo $str."<br>"; 
echo "</h4>"; 
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echo "输出 关键 字 P 一 共 出 现 ".(count($b)-1)." 次 "; // 利 用 count0 函 数 进 行 统计 
> 


国 秘笈 心 法 


心 法 领悟 119: split0 函 数 的 实现 原理 。 
splitO 正 则 表达 式 函数 是 将 字符 串 分 割 到 数组 中 , 如 果 字 符 串 中 有 n 个 与 pattern 匹配 的 项 目 , 则 返回 的 数 
组 将 包含 n+l 个 单元 ， 所 以 count0 在 计算 时 要 减 1。 


实例 120 


力 实例 说 明 


计算 机 的 每 一 步 操作 都 是 需要 时 间 的 ， 只 不 过 由 于 时 间 过 于 短暂 ， 用 户 感 觉 不 到 。 本 实例 通过 时 间 惟 函数 
microtime0O 计 算 查 询 操作 的 执行 时 间 ， 运 行 结果 如 图 2.94 所 示 。 


id:1 
查询 操作 所 用 时 间 为 ， aooaoseb 


图 2.94 计算 查询 操作 的 执行 时 间 


图 关键 技术 


获取 查询 操作 的 执行 时 间 ， 在 PHP 中 主要 是 使 用 microtime0 函 数 实 现 ， 其 语法 如 下 : 


mixed microtime ( [bool get_as_float] ); 


该 函数 获取 某 一 时 刻 的 时 间 戳 的 微 秒 数 。 
力 设计 过 程 
创建 index.php 文件 。 首 先 ， 连 接 数据 库 并 设置 页 面 的 编码 风格 ， 在 执行 查询 操作 的 开始 与 结束 的 两 个 时 间 


点 定义 两 个 变量 ， 分 别 利用 microtime0O 函 数 获取 两 点 时 间 戳 的 微 秒 数 。 然 后 计算 两 个 时 间 戳 的 差 值 ， 取 得 程序 
的 执行 时 间 ， 其 代码 如 下 : 


<?php 
Sconn = mysql_connect("localhost","root","111")or die(" 连 接 mysql 出 现 错误 "); // 连 接 MySQL 
mysql_select_db("db_database02",$conn): // 连 接 数 据 库 
$sql = "SELECT * FROM tb_select"; JSQL 语句 
$a = microtime(); // 取 得 当前 时 间 截 的 微 秒 数 
Srs = mysql_query($sql); // 查 询 操作 


while($rst = mysql_fetch_array($rs)) 
echo "id:".$rst[O]."<br>"; 
/取得 当前 时 间 戳 的 微 秒 数 


$b = microtime0: 
echo "查询 操作 所 用 时 间 为 : "(Sb-$aj." 秒 ": /输出 结果 
> 


[ED 说 明 : 本 实例 所 用 的 数据 表 没 有 足够 多 的 数据 ， 以 至 于 执行 速度 太 快 几乎 不 需要 时 间 ， 为 了 显示 结果 ， 笔 
者 人 为 让 程序 休 具 1 秒 钟 。 


国 秘笈 心 ; 
心 法 领悟 120: 知识 扩展 。 
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time0 和 mktime(O) 函 数 在 不 指定 参数 的 情况 下 具有 相同 的 作用 ， 都 是 返回 自从 UNIX 新 纪元 (格林 威 治 时间 
1970 年 1 月 1 日 00:00:00) 到 当前 时 间 的 秒 数 ， 而 microtime0) 函 数 只 是 单纯 取得 两 个 时 间 戳 的 微 秒 数 。 


高 级 | 


实例 121 趣味 指数 : 娘娘 妇女 


力 实例 说 明 


关键 字 描 红 技术 在 实例 088 中 已经 进行 过 讲解 ， 本 实例 是 通过 正则 表达 式 蔡 换 函数 preg_replace0 实 现 查询 
关键 字 描 红 ， 运 行 结果 如 图 2.95 所 示 。 


2.95 查询 关键 字 描 红 


图 关键 技术 
执行 蔡 换 或 关键 字 描 红 时 经 常 使 用 PHP 预定 义 函数 preg_replace0， 其 语法 如 下 : 


mixed preg replace ( mixed pattern, mixed replacement, mixed subjeet [, int limit] ); 
参数 说 明 : 

mixed pattem: 规定 替换 规则 。 

mixed replacement: 替换 部 分 。 

mixed subject: 蔡 换 内 容 的 源 信息 。 

主要 功能 : 执行 正则 表达 式 的 搜索 和 蔡 换 。 


图 设计 过 程 

创建 index.php 文件 。 首 先 连接 数据 库 并 设置 页 面 的 编码 风格 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 执 行 查询 操作 并 将 
文本 框 输入 的 信息 进行 描 红 处 理 ， 最 后 利用 正则 表达 式 函 数 preg_replace0 蔡 换 数据 信息 ， 其 代码 如 下 : 

<Ipbp 


$conn = mysql_connect("localhost","root","111")or die(" 连 接 mysql 出 现 错误 "); /连接 MySQL 

mysql_select_db("db_database02".$conn): /连接 数据 库 

mysql_query("SET NAMES GBK"): // 设 置 编码 格式 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
JSQL 语句 


$sql = "select * from tb_sel where tb_sel.name like (9%S_POST[text]%) or tb_sel.add like (9%S_POST[text]9%o) or tb_sel.sex like 
(%$_POST[text]%") or tb_sel.QQ like(%$_POST[text]%6)": 


$a=$ POST[text]: // 原 参数 
$b = "<b><font color=#FF0000>".$_POST[text]."</font></b>"; // 描 红 后 的 参数 
> 
<table border="1" bordercolor="#0033CC" cellspacing="0"><tr><td> 用 户 名 </td><td> 性 别 </td><td> 住 址 </td><td>QQ</td></tr> 
<?php 
while($rst = mysql fetch_array(Srs)){ /查询 输出 
Srste = preg_replace("/$a/",$b,Srst); /正则 著 换 
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/输出 表格 
echo "<tr><td>" Srste[name]."</td><td>" S$rste[sex]."</td><td>" Srste[add]."</td><td>". Srste[QQ]."</td></tr><br>"; 


} 
> 
</table> 
心 法 领悟 121: 使 用 preg_replace0 函 数 的 相关 说 明 。 


preg_replace0 函 数 的 每 个 参数 (除了 limit) 都 可 以 是 一 个 数组 。 如 果 pattern 和 replacement 都 是 数组 ， 
将 以 其 键 名 在 数组 中 出 现 的 顺序 来 进行 处 理 。 


高 级 | 
* | 


实例 122 趣味 指数 : 依依 依依 


力 实例 说 明 


前 面 的 实例 中 已 经 介绍 了 对 文件 类 型 的 相关 操作 , 本 实例 采用 正则 表达 式 函 数 preg_matchO 实 现 判断 上 传 文 
件 的 类 型 ， 运 行 结果 如 图 2.96 所 示 。 


F:\xampp\xampp\lice 
上 传 为 图 片 类 型 
图 2.96 判断 上 传 文件 的 类 型 


力 关键 技术 

使 用 preg_match0 函 数 进行 正则 表达 式 匹配 ， 详 细 说 明 参见 实例 110。 
图 设计 过 程 

创建 index php 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 利 用 preg_matchO 正 则 表达 式 函 数 将 上 传 的 数据 信息 进行 匹 
配 并 输出 结果 ， 其 代码 如 下 ， 


if($_POST[sub){ // 让 条 件 语句 
if(preg_match("/jpg/".strtolower($_POST[text)){ // 通 过 正则 表达 式 函 数 判 断 类 型 
echo "上 传 为 图 片 类 型 "; 
yelse{ 
iflpreg_match("/.rar/",: tt POST[text)) { 
echo "上 传 为 压缩 包 类 型 
jelsef 
echo "其 他 文件 类 型 "; 
} 
} 


} 
?> 


力 秘笈 心 ; 


心 法 领悟 122: 知识 扩展 。 
本 实例 使 用 的 是 ff...else.…. 语 句 榜 套 从 结构 上 看 不 是 很 明朗 ,读者 可 以 运用 switch 语句 改写 此 实例 ， 相 信 
在 系统 运行 效率 上 会 有 所 提高 。 
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实例 123 


力 实例 说 明 


用 户 在 购买 电子 商务 网 站 的 商品 时 ， 商 品 一 般 都 是 以 快递 或 邮寄 的 方式 传递 到 用 户 手 中 ， 所 以 如 果 用 户 不 
能 正确 地 填写 邮寄 地 址 或 邮政 编码 , 就 有 可 能 造成 不 必要 的 损失 。 本 实例 通过 正则 表达 式 函 数 preg_match0 验 证 
用 户 提交 的 邮政 编码 格式 是 否 正确 ， 运 行 结果 如 图 2.97 所 示 。 


图 2.97 验证 邮政 编码 是 否 有 效 


图 关键 技术 


(1) preg_match0 函 数 ， 进行 正则 表达 式 匹 配 ， 详 细 参 数 参见 实例 110。 
(2) 正则 表达 式 ， 对 邮政 编码 格式 进行 验证 。 
"0-9]{6}"; 
图 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 ， 利 用 preg_match0 正 则 表达 式 函 数 对 文本 框 的 输入 信息 进行 
匹配 并 输出 提示 ， 其 代码 如 下 : 
局 


php 
这 S$_POST[sub]){ // 通 过 POST 方式 传递 参数 
require_once("inc.php"); // 包 含 文件 
if(preg_match("/[0-9]{6}/",trim($_POST['text])){ // 正 则 表达 式 


show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); 。“// 显 示 信息 
jelsef 
show_error(" 信 息 提示 "" 格 式 不 正确 "…"index.php"): 


} 


> 


国 秘笈 心 法 
心 法 领悟 123: 什么 是 邮政 编码 。 
邮政 编码 是 为 了 实现 邮政 分 拣 自 动 化 和 邮政 网 络 数字 化 设置 的 ， 以 加 快 邮件 邮递 速度 。 目 前 世界 上 有 40 多 


个 国家 先后 实行 了 邮政 编码 制度 ， 并 以 此 作为 衡量 一 个 国家 通信 技术 和 邮政 服务 水 平 的 标准 之 一 。 各 国 邮 政 编 
码 规则 并 不 统一 。 


2.10 数 组 
数组 是 对 大 量 数据 进行 组 织 和 管理 的 有 效 手 段 之 一 ， 通 过 数组 的 强大 功能 ， 可 以 对 大 量 性 质 相同 的 数据 进 
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行 存储 、 排 序 、 插 入 及 删除 等 操作 ， 从 而 可 以 有 效 地 提高 程序 开发 效率 及 改善 程序 的 编写 方式 。 
实例 
力 实例 说 明 


如 果 只 是 想 保 存 几 个 数据 就 没有 必要 和 数据 库 交互 ， 此 时 可 以 选用 数组 。 本 实例 通过 数组 函数 array0 实 现 
创建 并 输出 数组 ， 运 行 结果 如 图 2.98 所 示 。 


| 书写 字符 率 以 # 号 分 割 创建 数组 ] [ 输出 数组 
Array ( [0).=»123 [2] 之 789) 


图 2.98 输出 数组 


图 关键 技术 
array(); 新 建 一 个 数组 。 


array array ( [mixed …] ); 

参数 mixed 的 语法 为 “key=>value”， 多 个 mixed 参数 之 间 用 逗号 隔 开 ， 分 别 定义 了 索引 和 值 。 索 引 可 以 
是 字符 串 或 数字 。 如 果 省 略 了 索引 将 是 目前 最 大 的 整数 索引 +1。 如 果 定 义 了 两 个 完全 一 样 的 索引 ， 则 后 面 一 个 
会 覆盖 前 一 个 。 数 组 中 的 各 数据 元 素 的 数据 类 型 可 以 不 同 ， 也 可 以 是 数组 类 型 。 当 mixed 是 数组 类 型 时 ， 该 数 
组 就 是 二 维 数组 。 


力 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 创 建 数组 ”按钮 时 ,首先 ,判断 文本 框 信息 是 否 为 空 ， 如 果 为 空 则 输出 提示 ， 


否则 将 文本 框 信息 保存 在 SESSION 变量 中 ; 当 单 击 “ 输 出 数组 ”按钮 时 ， 首先， 判断 网 页 中 是 否 存在 SESSION 
变量 ， 如 果 存 在 变量 则 利用 字符 串 拆 分 函数 进行 拆 分 并 打印 输出 ， 其 代码 如 下 : 


php 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
if($_POST[text] = ""){ // 如 果 文本 框 为 空 
echo "<script>alert( 您 创建 了 一 个 空 数 组 ):location href="index.php'</script>"; /输出 提示 
jelsef 
S$_SESSION[array] = $_POST[text]: // 将 结果 保存 在 SESSION 中 
echo "<script>alert( 创建 数组 成 功 ):location href='index.php'</script>"; /| 提示 
} 
} 
if($_POST[sub2){ /通过 POST 方式 传递 参数 
iflisset($_SESSION['aray]){ // 如 果 SESSION 存在 
Sarray = explode("#".$_SESSION['aray"]): /分割 字 符 串 
Print_r($array): /打印 
session_destroy(): 1/ 销毁 SESSION 
jelsef 
echo "<seript>alert(' 请 先 创建 数组 ):location hre 人 index.php'</script>": /提示 
} 
) 
2> 
力 秘笈 心 法 


心 法 领悟 124: 数组 的 重要 作用 。 


数组 是 PHP 基础 语言 中 很 重要 的 一 部 分 ， 灵 活 运用 数组 会 起 到 事半功倍 的 效果 。 
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i 
实例 125 | ao 


力 实例 说 明 


数组 下 标 默认 是 以 0 为 开始 键 值 的 整 型 数据 ， 如 果 想 取得 数组 元 素 的 个 数 就 要 使 用 count0 函 数 。 本 实例 通 
过 count0 函 数 统计 数组 元 素 个 数 ， 运 行 结果 如 图 2.99 所 示 。 


图 2.99 统计 数组 元 素 个 数 


图 关键 技术 
在 PHP 中 ， 应 用 count0 函 数 对 数组 中 的 元 素 个 数 进行 统计 ， 其 语法 如 下 : 


int count ( mixed array [, int mode]) 

参数 说 明 : 

array: 必 选 参数 ， 指 定 被 统计 的 数组 。 

mode: 可 选 参数 ， 其 参数 值 为 COUNT_RECURSIVE (或 1) ， 如 选中 此 参数 ， 本 函数 将 递归 地 对 数组 计 
数 。 对 计算 多 维 数 组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 是 0。 
图 设计 过 程 

创建 index.php 文件 ,首先 定义 数组 变量 并 为 此 变量 赋值 ,然后 利用 count0 函 数 输出 数组 元 素 的 个 数 ， 其 代 
码 如 下 : 


<?php 

$a = array(1', 精 细 ',asd',asd123"); /声明 数组 

echo "数组 中 存在 元 素 ".count($a)." 个 "; 1/ 计 算数 组 元 素 个 数 
?> 


国 秘笈 心 法 
心 法 领悟 125， 使 用 count0 函 数 的 注意 事项 。 


如 果 count0 函 数 的 操作 对 象 是 NULL， 那 么 返回 结果 为 0。count0 函 数 对 没有 初始 化 的 变量 返回 0， 但 对 于 空 
的 数组 也 会 返回 0。 如果 要 判断 变量 是 否 初始 化 ， 则 可 以 应 用 isset0 函 数 。 另 外 ，countO 函 数 不 能 识别 无 限 递归 。 


2 
实 伯 
看 实例 说 明 
数组 元 素 的 个 数 和 元 素 值 是 可 以 改变 的 。 本 实例 通过 数组 函数 array_push0 向 数组 中 添加 元 素 ， 运 行 结果 如 


图 2.100 所 示 。 
| 厦 数 组 : Array (I0] = > 少 细 加 = >asdB = 
添加 元 素 后 的 数组 >: -> 四 => 精细 [2 - 一 > asd123 [名 二 分 
6 哈 ) 


2.100 ”向 数组 中 添加 元 素 
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国 关键 技术 
在 PHP 中 ， 向 数组 中 添加 元 素 使 用 arny_push0 本 数 ， 其 语法 如 下 ; 


int armray_ push ( array array. mixed var [, mixed 

参数 说 明 : 

array array: 原 数组 。 

mixed var: 压 入 的 数据 元 素 。 

该 函数 将 array 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 array 的 末尾 。 


图 设计 过 程 
创建 index php 文件 ， 首 先 ， 定 义 数组 变量 ， 并 为 数组 变量 赋值 。 然 后 ， 利 用 amray_ push0 函 数 向 数组 中 添 
加 元 素 并 打印 数组 输出 信息 ， 其 代码 如 下 : 


<php 
$a = array(1', 精 细 ''asd',asd123"); /声明 一 个 数组 
echo " 原 数 组 : 
print_r($a)."<br>"; /输出 数组 
array_push($a,' 了 哈哈"); // 向 数组 末尾 添加 元 素 
echo "<br> 添 加 元 素 后 的 数组 :"; 
print_r($a); /打印 添加 元 素 后 的 数组 

?> 

国 秘笈 心 ; 


心 法 领悟 126: 使 用 array_push0 函 数 的 相关 说 明 。 
如 果 用 array_push0 函 数 单纯 地 给 数组 增加 一 个 单元 ， 不 如 选用 “$array[]=”， 因 为 这 样 没有 调用 函数 的 
额外 负担 。 


力 实例 说 明 


创建 数组 时 ， 由 于 朴 忽 将 元 素 内 容 书写 错误 ， 更 改 错误 的 元 素 内容 可 以 通过 数组 键 值 实现 。 本 实例 通过 数 
组 下 标 〈 键 值 ) 实现 将 数组 中 指定 索引 位 置 的 元 素 赫 换 ， 运 行 结果 如 图 2.101 所 示 。 


A 中 => 精细 [2] =>asd [ 123 ) 
指定 索引 元 ay ( [ol => 工 加 二 > > 经 济 团 => 
关公 

的 元 素 发 生 更 改 


图 2.101 将 数组 中 指定 索引 位 置 的 元 素 普 换 


| bodedododl 


力 关键 技术 


PHP 数字 索引 由 数字 组 成 ， 下 标 从 0 开始 ， 数 值 索引 一 般 表 示 数 组 元 素 在 数组 中 的 位 置 ， 数 字 索 引 数组 默 
认 索 引 值 从 数字 0 开始 ， 不 需要 特别 的 指定 ，PHP 会 自动 为 索引 数组 的 键 名 赋 一 个 整数 值 ， 然 后 从 这 个 值 开始 
自动 增 量 ， 当 然 也 可 以 指定 某 个 位 置 开 始 保存 数据 。 


图 设计 过 程 
创建 ndex php 文件 ， 定 义 数组 变量 并 通过 数组 下 标 输出 元 素 ， 其 代码 如 下 : 
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echo " 原 数组 元 素 :"; 
$a = array(1',' 精 细 ','asd''asd123); // 定 义 数组 
print_r($a); // 打 印 数组 
echo "<br> 指 定 索引 元 素 蔡 换 后 的 数组 : "; 
SaD] = 经济; // 根 据 数组 下 标 更 改元 素 
print_r($a); // 打 印 更 改 后 的 数组 
echo "<br> 键 值 2 的 元 素 发 生 更 改 "; 
> 
二 
力 秘笈 心 法 


心 法 领悟 127: 使 用 数组 键 值 的 注意 事项 。 
当 使 用 “组 名 称 [ 键 值 ]” 这 样 的 格式 时 ， 要 注意 数组 键 值 是 从 0 开始 的 ， 所 以 本 例 中 更 改 键 值 为 2 的 元 素 ， 
其 实 是 数组 中 的 第 3 个 元 素 。 


实例 128 趣味 指数 : 走 丰 页 本 | 


力 实例 说 明 
在 数组 元 素 比较 多 的 情况 下 , 想 要 取得 数组 中 的 最 后 一 个 元 素 可 以 通过 5 
获取 数组 中 最 后 - 


先 计算 元 素 的 个 数 再 通过 下 标 取得 ,还 可 以 通过 函数 取得 。 本 实例 通过 数组 
函数 aray_ pop0 实 现 获取 数组 中 的 最 后 一 个 元 素 ,运行 结果 如 图 2.102 所 示 。 图 2 10》 获取 数组 中 最 后 一 个 元 素 


图 关键 技术 
使 用 array pop0 函 数 获取 并 返回 array 数组 的 最 后 一 个 单元 ， 并 将 数组 array 的 长 度 减 1， 其 语法 如 下 : 


mixed array_pop ( array array); 
图 设计 过 程 

创建 index.php 文件 。 首先 定义 数组 变量 $a 并 为 此 数组 变量 赋值 ， 然 后 利用 函数 array_pop0 弹 出 数组 中 的 最 
后 一 个 元 素 并 输出 结果 ， 其 代码 如 下 : 


Iphp 


$a = array('a','b',. hi; // 声 明 数组 
echo "获取 数组 中 最 后 一 个 元 素 是 : "array_pop(Sa): /返回 数组 中 最 后 一 个 元 素 
> 
力 秘笈 心 法 


心 法 领悟 128: 使 用 array_pop0 函 数 的 相关 说 明 。 

在 使 用 array_popO 函 数 时 ， 数 组 中 最 后 一 个 元 素 是 被 取出 而 不 是 被 复制 ， 即 每 次 使 用 此 函数 ， 数 组 元 素 就 
会 减少 一 个 。 如 果 数 组 为 空 〈 或 者 不 是 数组 ) 将 返回 NULL。 
高 级 | 


实例 129 趣味 指数 : fi 


力 实例 说 明 
在 数组 中 键 值 是 唯一 的 ， 但 是 元 素 的 值 是 可 以 重复 的 。 想 要 删除 数组 元 素 中 重复 的 值 可 以 使 用 函数 
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array uniqueO0。 本 实例 是 通过 数组 函数 array_unique0 去 除数 组 中 的 重复 元 素 值 ， 运 行 结果 如 图 2.103 所 示 。 


a [=>b[2>aBl =>a[9 => ffgl 
上 “各 De 
(=>a [Y=>5 Bl =>f0=> hy 


司 2.103 ”去 除数 组 中 的 重复 元 素 


力 关键 技术 
在 PHP 中 ， 通 过 array unique0 函 数 去 除数 组 中 的 重复 元 素 ， 其 语法 如 下 : 


array array_unique ( array array); 
参数 array 为 指定 参数 的 数组 ， 其 返回 值 为 一 个 没有 重复 元 素 的 新 数组 。 
图 设计 过 程 
创建 index.php 文件 。 首 先 创建 数组 变量 $a 并 为 其 赋值 ， 然 后 利用 array_unique0) 函 数 去 除数 组 中 的 重复 元 
素 值 ， 最 后 打印 数组 ， 其 代码 如 下 : 
有 $a = amray(avbvavdvavfuavbhva; /定义 数组 
echo " 原 数 组 元 素 为 :"; 
Print_r($a); // 打 印 数 组 
echo "<br> 去 除 重复 项 后 的 数组 为 :"; 


Print_r(array_unique($a)); // 输 出 去 除 重复 项 的 数组 
> 


国 秘笈 心 ; 
心 法 领悟 129: 使 用 array_uniqueO 函 数 的 原理 。 


使 用 array_uniqueO 函 数 的 原理 是 先 将 值 作为 字符 串 排序 ， 然 后 对 每 个 值 只 保留 第 一 个 遇 到 的 键 名 ， 而 忽略 
所 有 后 面 的 键 名 。 但 这 并 不 意味 着 在 未 排序 的 数组 中 同一 个 值 的 第 一 个 出 现 的 键 名 会 被 保留 。 


; a a 
图 实例 说 明 


实例 109 介绍 了 字符 串 与 数字 之 间 的 转换 ， 下 面 来 介绍 字符 串 与 数组 之 间 的 转换 。 本 实例 通过 强制 类 型 转 
换 实现 字符 串 与 数组 的 转换 ， 运 行 结 果 如 图 2.104 所 示 。 


计时 转 抽 为 数组 DE 
Hat 


图 2.104 字符 串 与 数组 的 转换 


图 关键 技术 


虽然 PHP 是 弱 类 型 语言 , 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 ， 在 
变量 前 加 上 用 括号 括 起 来 的 类 型 名 称 即 可 。 人 允许 转换 的 类 型 如 表 2.7 所 示 。 
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表 2.7 类 型 强制 转换 


转换 操作 符 转换 类 型 举例 
(boolean) 转换 成 布尔 型 (boolean)$num、(boolean)$str 
(string) 转换 成 字符 型 (string)$boo、(string)$flo 
(integer) 转换 成 整 型 (integer)$boo、(integer)$str 
(float) 转换 成 浮 点 型 (floa)$str、(float)$str 

(array) 转换 成 数组 (array)$str 


转换 成 对 象 


objecb$str 
力 设计 过 程 

创建 index.php 文件 。 首 先 定义 数组 变量 并 为 此 变量 赋值 ， 然 后 利用 强制 类 型 转换 的 方法 将 字符 串 类 型 转换 
为 数组 类 型 ， 其 代码 如 下 : 

<?pl 


hp 
$a="123"; // 声 明 字符 串 变量 
Sb = (array)$a: // 将 字符 串 转换 为 数组 
echo "字符 串 转换 为 数组 : "; 
Print_r($b); /打印 数组 
echo "<hr>"; 
Sc =array('1); // 定 义 数 组 
$d = (string)$e; // 将 数组 转换 为 字符 串 
echo"<br> 数 组 转换 为 字符 串 : ": 
echo $d; /输出 字符 串 
> 
> i 
力 秘笈 心 法 


心 法 领悟 130: 将 数组 强制 转换 成 字符 串 的 注意 事项 。 
将 数组 强制 转换 成 字符 串 时 ， 数 组 将 被 转换 成 字符 串 "Array"， 因 此 无 法 通过 echo0 或 者 printO 函 数 来 输出 
数组 的 内 容 。 


实例 131 


国 实例 说 明 
本 实例 通过 shuflle0 函 数 实现 对 数组 元 素 进行 随机 排序 ， 运 行 结果 如 图 2.105 所 示 。 


原 数组 元 素 顺 序 为 : 23 asd 
经 随机 排序 后 - 习 和 b 


2.105 ”对 数组 元 素 进行 随机 排序 


力 关键 技术 
在 PHP 中， 将 数组 元 素 进行 随机 排序 使 用 shuffle0 函 数 ， 其 语法 如 下 : 
使 用 该 数 将 数组 打 总 ， 随 机 排序 。 
图 设计 过 程 
新 建 index.php 文件 。 首 先 定义 数组 变量 ， 利 用 srand0 函 数据 下 随机 数 发 生 器 种 子 ， 然 后 利用 shufle0 函 数 
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将 数组 打 乱 ， 最 后 输出 数组 元 素 ， 其 代码 如 下 : 
<Iphp 
Snumbers = amay( 经 济 vavb:"123"vasd; 
echo " 原 数组 元 素 顺序 为 : 经 济 ab 123 asd"; 
srand ((float)microtime()*1000000): 
shuffle (Snumbers): 
echo "<br> 经 随机 排序 后 : "; 
while (list (, Snumber) = each ($numbers)) { 
echo "$number ": 
} 


?> 


心 法 领悟 131: 使 用 shuffle0) 函 数 的 注意 事项 。 
在 使 用 shuffle0 函 数 将 数组 打 乱 时 ， 必 须 用 srand0 函 数 播 下 本 函数 的 随机 数 发 生 器 的 种 子 ， 否 则 得 不 到 预 
期 结果 。 


图 实例 说 明 

可 以 把 随机 抽取 数组 中 的 元 素 看 成 一 个 彩票 抽奖 的 大 摇 箱 ， 在 原理 上 两 者 是 没什么 区 别 的 ， 但 是 彩票 抽奖 
的 大 摇 箱 可 能 存在 一 点 点 的 偶然 性 ， 例 如 大 摇 箱 里 的 球 弹力 不 同等 。 本 实例 通过 随机 函数 rand0 实 现 随机 抽取 
数组 中 的 元 素 ， 运 行 结果 如 图 2.106 所 示 。 


rm, EN 
随机 取得 数组 的 元 素 是 


2.106 ”随机 抽取 数组 中 元 素 


ea 


高 级 


| 
趣味 指数 : 傅 傅 痕 良 | 


力 关键 技术 


应 用 rand0 函 数 获取 随机 数值 ， 并 将 随机 数值 指向 数组 下 标 从 而 实现 随机 获取 指定 元 素 的 值 。rand0 函 数 的 
语法 如 下 : 

int rand ( [int min, int max]): 

参数 说 明 : 

min: 随机 数 的 最 小 值 。 

max: 随机 数 的 最 大 值 。 


力 设计 过 程 

创建 PHP 脚本 。 首 先 定义 数组 变量 并 为 数组 变量 赋值 ， 然 后 利用 rand0 函 数 获取 0~4 中 的 一 个 随机 数 ， 并 
将 此 随机 数 赋 给 数组 变量 作为 数组 变量 的 键 值 ， 最 后 输出 此 数组 变量 ， 其 代码 如 下 : 

<2php 


$numbers = array(' 经 济 ",'a','b'"123',asd"); /定义 数组 

echo "数组 :"; 

print_r(Snumbers): 

Srand = rand(0.4): /创建 一 个 0~4 的 随机 数字 


echo "<br> 随 机 取得 数组 的 元 素 是 : ".Snumbers[Srand]: 。“// 将 随机 数字 作为 键 值 获取 数组 元 素 
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力 秘笈 心 法 


心 法 领悟 132: 随机 函数 rand0 的 相关 说 明 。 
在 使 用 随机 函数 rand0 时 ， 如 果 没 有 提供 可 选 参数 min 和 max， 该 函数 返回 0-RAND_MAX 之 间 的 伪 随 
机 数 。 例 如 ， 想 得 到 10~30 (包括 10 和 30) 之 间 的 随机 数 ， 使 用 rand(5, 15)。 


F NA i 
图 实例 说 明 


二 维 数组 可 以 简单 理解 为 数组 元 素 中 还 包含 一 个 数组 。MySQL 图 形 化 管理 工具 phpMyAdmin 中 存储 的 每 
个 数据 表 其 实 就 是 一 个 二 维 数组 。 本 实例 实现 二 维 数组 中 数据 的 输出 ， 运 行 结果 如 图 2.107 所 示 。 


输出 二 维 数 组 $a ; Ar > Array ([0] =>alI 了 = => Aray([O SC 
=> 4) BY 3> Pr > & 回 二 及 
园 出 一 准 吉 委 9a 键 填 7 $a[1] : Array ( [01 => a (J 


图 2.107 二 维 数组 的 输出 


图 关键 技术 


如 果 创 建 的 数组 中 的 元 素 值 都 是 变量 ， 此 数组 称 为 一 维 数组 ， 如 果 创 建 的 数组 元 素 值 仍然 是 数组 ， 那 么 就 
称 为 二 维 数组 。 也 就 是 说 ， 一 个 数组 的 元 素 如 果 仍 是 一 个 一 维 数 组 ， 则 称 这 个 数组 是 二 维 数组 。 
看 设计 过 程 
创建 index.php 文件 。 首 先 定义 二 维 数组 变量 $a 并 为 此 变量 赋值 ， 然 后 利用 print_r0 函 数 实现 二 维 数 组 的 输 
出 ， 其 代码 如 下 : 
六 echo 输出 二 维 数 组 $a: '; 
$a= ee ,b),2=>array('e',d"),3=>array('e',f)); 1/ 创建 一 个 二 维 数组 
Print_r($a)."<br 


echo -0 输出 二 维 数组 $a 键 值 为 1 元 素 $a[1]:“ 
print_r($a[1]); /打印 二 维 数组 键 值 为 1 的 元 素 


> 


国 秘笈 心 法 

心 法 领悟 133: 对 PHP 中 数组 的 理解 。 

PHP 中 的 数组 实际 上 是 一 个 有 序 图 。 该 图 是 一 种 把 values 映射 到 keys 的 类 型 ， 此 类 型 在 很 多 方面 做 了 
优化 ， 因 此 可 以 把 它 当成 真正 的 数组 来 使 用 ， 或 列表 (矢量 ) 、 散 列表 (是 图 的 一 种 实现 ) 、 字 典 、 集 合 、 栈 、 
队列 以 及 更 多 可 能 性 。 因 为 可 以 用 另 一 个 PHP 数组 作为 值 ， 也 可 以 很 容易 地 模拟 树 。 


和 值 级 | 
实例 t 
sx | wn 
力 实例 说 明 
每 个 数组 元 素 都 是 由 键 名 和 值 两 部 分 组 成 的 ， 想 要 获取 它们 可 以 通过 循环 来 实现 。 本 实例 通过 foreach 语句 
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获取 数组 当前 的 键 名 和 值 ， 运 行 结果 如 图 2.108 所 示 。 


EE 
值 为 323 你 对 


图 2.108 ”获取 键 名 值 


图 关键 技术 


数组 中 的 每 个 实例 都 包含 两 项 : 键 和 值 。 其 中 键 可 以 是 数字 、 字 符 串 或 者 数字 和 字符 串 的 组 合 ， 用 于 标识 
数组 中 相应 的 值 ， 而 值 被 称 为 数组 中 的 元 素 ， 可 以 定义 为 任意 数据 类 型 ， 甚 至 是 混合 类 型 ， 最 终 通过 键 来 获取 
相应 的 值 。 


图 设计 过 程 
新 建 index.php 文件 。 首 先 ， 定 义 数组 变量 $array 并 且 为 其 赋值 。 当 单 击 “ 获 取 键 名 ”按钮 时 ， 利 用 foreach 


语句 遍历 数组 并 输出 所 有 元 素 的 键 值 ， 当 单 击 “ 获 取 值 ”按钮 时 ， 同 样 通过 foreach 语句 获取 数组 元 素 的 value 
值 并 且 输 出 ， 其 代码 如 下 : 
< 


hp 
Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 ","456"=>"mingri"); // 定 义 数组 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
echo " 键 名 为 :"; 
foreach($array as $key => $value){ /| 遍历 数组 
echo $key."&nbsp:&nbspi&nbsp:&nbsp:": // 输 出 键 值 
} 
} 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
echo " 值 为 :"; 
foreach($array as $key => $value){ // 遍 历数 组 
echo $value."&nbsp:&nbsp:;&nbsp:&nbsp:": // 输 出 值 
下 
?> 
图 秘笈 心 法 
心 法 领悟 134: 使 用 foreach 语句 的 注意 事项 。 
foreach 语句 只 能 用 于 数组 。 


实例 135 


高 级 | 
| 
| 


趣味 指数 : 位 食 食 食 


国 实例 说 明 


PHP 大 型 的 程序 开发 往往 使 程序 员 焦头烂额 ， 有 时 程序 员 不 确定 自己 定义 的 数组 中 是 否 存 在 需要 的 元 素 。 
本 实例 通过 array_key_exists0 函 数 检 测 数 组 中 是 否 存 在 某 个 值 ， 运 行 结果 如 图 2.109 所 示 。 


Ty 


图 2.109 检测 数组 中 是 否 存在 某 元 素 
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力 关键 技术 
在 PHP 中 ， 检 测 数 组 中 是 否 存 在 某 个 值 ， 使 用 array key_exists0 函 数 ， 其 语法 如 下 : 


bool array key _exists ( mixed key, array search ); 

参数 说 明 : 

mixed key: 检测 元 素 。 

array search: 源 数 组 。 

该 函数 检查 给 定 的 键 名 或 索引 是 否 存在 于 数组 中 。 


图 设计 过 程 
新 建 index.php 文件 ， 定 义 数组 变量 $array 并 为 其 赋值 ， 当 单 击 “ 检 测 ” 按 钮 时 ， 利 用 array_key_exists0 函 
数 判断 接收 到 的 文本 框 信息 是 否 存在 于 指定 的 数组 元 素 中 ,并 且 根 据 返 回 值 给 出 相应 的 提示 信息 ， 其 代码 如 下 : 


<?php 
Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 ","456"=>"mingri"); // 定 义 数组 
这 $_POST[sub]){ /通过 POST 方式 传递 参数 
iflarray_key_exists($_POST[text].Sarray))f // 检 测 是 否 存在 元 素 
echo "<script>alert(' 数 组 中 存在 此 元 素 ):</script>": /提示 
jelsef 
echo "<script>alert( 数 组 中 不 存在 此 元 素 "):</script>"; /| 提示 
} 
} 
> 
国 秘笈 心 ; 


心 法 领悟 135:; array_key_exists0 函 数 的 相关 说 明 。 
array_key_exists() 函 数 在 给 定 的 key 存在 于 数组 中 时 返回 TRUE，key 可 以 是 任何 能 作为 数组 索引 的 值 。 
array_key_existsO 函 数 也 可 用 于 对 象 。 


力 实例 说 明 
本 实例 通过 current0 函 数 获取 数组 中 的 当前 单元 ， 运 行 结果 如 图 2.110 所 示 。 


获取 单元 
PHP 范 例 宝典 


图 2.110 获取 数组 中 的 当前 单元 


| 克 刘 去 ， 


力 关键 技术 
current0 函 数 的 主要 功能 是 返回 数组 中 的 当前 单元 ， 其 语法 如 下 : 


mixed current ( array &array ); 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数 组 变量 并 为 其 赋值 ， 当 单 击 “获取 单元 ”按钮 时 ， 通 过 currentO 


函数 获取 数组 当前 元 素 ， 其 代码 如 下 : 
和 $array =array(" 编 程 "=>"PHP 范例 宝典 "."soft"=>" 你 好 ","456"=>"mingri"): // 定 义 数 组 
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if($_POST[sub){ /通过 POST 方式 传递 参数 
echo current($array); /获取 当前 数组 中 的 单元 
} 


?> 


| (2) 将 该 文件 存储 于 \MR\02\136 文件 夹 中 ， 命 名 为 mdex.php。 运 行 结果 如 图 2.110 所 示 。 
图 秘笈 心 法 


心 法 领悟 136: 使 用 currentO 函 数 的 相关 说 明 。 

currentO 函 数 返 回 当前 被 内 部 指针 指向 的 数组 单元 的 值 ， 并 不 移动 指针 。 如 果 内 部 指针 指向 超出 了 单元 列表 
的 末端 ，current0 函 数 返 回 FALSE。 如 果 数 组 包含 有 空 的 单元 0 或 者 ""， 空 字符 串 ) ， 则 本 函数 在 碰 到 这 个 单 
元 时 也 返回 FALSE。 


实例 137 


力 实例 说 明 
通过 rand0 函 数 可 以 随机 抽取 数组 中 的 元 素 。 下 面 再 通过 另外 一 个 函数 array_rand0 实 现 从 数组 中 随机 取出 
元 素 ， 运 行 结果 如 图 2.111 所 示 。 


获取 单元 
获取 随机 元 素 PHP 范 
图 2.111 从 数组 中 随机 取出 元 素 


图 关键 技术 


当 用 户 想 从 数组 中 取出 一 个 或 多 个 单元 时 ， 使 用 array_rand0 函 数 是 非常 有 用 的 ， 它 与 rand0 函 数 获取 随机 
数组 元 素 的 原理 大 同 小 异 ， 其 语法 如 下 : 

ined array_ rand (aray input [int nn, req] 

参数 说 明 : 

array input: 传 入 的 数组 。 

int num req: 可 选 参数 ， 定 义 输出 数组 元 素 的 个 数 。 


图 设计 过 程 
(1) 创 建 PHP 脚本 文件 .首先 ,定义 数组 变量 Sarray 并 为 其 赋值 , 当 单 击 “ 获 取 单 元 ”按钮 时 ,通过 array_rand() 
函数 获取 数组 中 的 随机 元 素 值 ， 其 代码 如 下 : 
<2php 


$array =array(" 编 程 "=>"PHP 范例 宝典 ","soft"=>" 明 日 科技 "."456"=>"mingri"); // 定 义 数组 

if($_POST[sub){ /通过 POST 方式 传递 参数 
S$rand keys = array_rand($array, 1); /获取 数组 的 随机 键 值 
echo "获取 随机 元 素 : ".$array[$rand_keys] : /输出 随机 元 素 值 

} 

> 
(2) 将 该 文件 存储 于 \MR\02\137 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.111 所 示 。 
力 秘笈 心 法 


心 法 领悟 137: 使 用 array_rand0 函 数 的 相关 说 明 。 
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array_randO 函 数 在 从 数组 中 取出 一 个 或 多 个 随机 的 元 素 时 相当 有 用 。 它 接受 $array 作为 输入 数组 和 一 个 可 
选 的 参数 num req， 指 明 想 取出 多 少 个 元 素 。 如 果 没 有 指定 ， 默 认为 1。 如 果 只 取出 一 个 ，array_rand0 函 数 返 
回 一 个 随机 元 素 的 键 名 ， 和 否则 就 返回 一 个 包含 随机 键 名 的 数组 。 这 样 用 户 就 可 以 随机 从 数组 中 取出 键 名 和 值 。 


人 二 
国 实例 说 明 


数组 与 数组 之 间 是 彼此 独立 的 ， 但 是 两 个 数组 可 以 合并 到 一 起 成 为 一 个 新 数组 。 本 实例 通过 数组 函数 
array_merge() 实 现 合并 数组 ， 运 行 结果 如 图 2.112 所 示 。 


[2] => Java 编程 3] => CH 编程 4] - 


图 2.112 合并 数组 


图 关键 技术 


数组 的 合并 应 用 的 是 array_merge0 函 数 ， 其 语法 如 下 : 
array array_merge ( array array1 [, array array2 [, array 了 ] ); 

参数 说 明 : 

array array1: 数组 1。 

array array2: 数组 2。 


力 设计 过 程 

新 建 index.php 文件 。 首先 , 定义 两 个 数组 变量 并 为 其 赋值 。 当 单 击 “ 合 并 数组 ”按钮 时 , 利用 array_merge0 
函数 合并 数组 ， 并 打印 合并 后 的 数组 ， 其 代码 如 下 : 

<?php 


Sarray =array(" 编 程 "=>"PHP 范例 宝典 "."soft"=>" 明 日 科技 "."456"=>"mingri"): /定义 数组 1 

echo "数组 1: "; 

print_r(Sarray); /打印 数组 

echo "<br><br>"; 

Sarr = array("PHP 编程 "."Java 编程 "."C# 编 程 "."ASP.NET 编程 "); /定义 数组 2 

echo" 数 组 2: ": 

print r(Sam; // 打 印 数组 

echo "<br><br>"; 

if($_POST[sub) { /通过 POST 方式 传递 参数 
echo "合并 后 的 数组 "; 
Print_r(array_merge($array.$arr)): // 打 印 合并 后 的 数组 

国 } 
、、 
图 秘笈 心 法 


心 法 领悟 138: 使 用 array_mergeO 函 数 的 相关 说 明 。 
array_merge0 函 数 将 一 个 或 多 个 数组 的 单元 合并 起 来 ， 一 个 数组 中 的 值 附加 在 前 一 个 数组 的 后 面 ， 返 回 作 
为 结果 的 数组 。 如 果 输 入 的 数组 中 有 相同 的 字符 串 键 名 ， 则 该 键 名 后 面 的 值 将 覆盖 前 一 个 值 。 如 果 数 组 包含 数 
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字 键 名 ， 后 面 的 值 将 不 会 覆盖 原来 的 值 ， 而 是 附加 到 后 面 。 如 果 只 给 了 一 个 数组 并 且 该 数组 是 数字 索引 的 ， 则 
键 名 会 以 连续 方式 重新 索引 。 


| 


高 级 
起 味 指数 : 贾 页 页 页 


实例 139 


力 实例 说 明 


存在 数组 的 合并 函数 当然 也 就 存在 数组 的 拆 分 函数 。 本 实例 通过 array_chunkO 函 数 实现 数组 的 拆 分 ， 运 行 
结果 如 图 2.113 所 示 。 


> C# 编 程 [站 => ASP:NET 编 程 ) 


拆 分 后 的 数组 : Ar = 让 Array ( [0] => PHB 编 程 [十 了 半 扣 va 编程 ) [1] => Avray; 
(IO 二 C# 编 程 呈 隐隐 天 eg) a 饮 伯 


图 2.113 拆 分 数组 


图 关键 技术 


array_chunk(O) 函 数 可 将 一 个 数组 分 割 成 多 个 ， 其 原理 是 将 原 有 数据 根据 传递 的 参数 不 同 分 割 成 多 个 二 维 数 
组 。array_chunkO 函 数 的 语法 如 下 : 

amray array_chunk ( array input int size [, bool preserve keys] ); 

参数 说 明 : 

array input: 源 数组 。 

int size: 分 割 成 指定 数量 的 数组 。 


看 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数组 变量 并 为 其 赋值 ， 当 单 击 “ 拆 分 数组 ”按钮 时 ， 打 印 被 拆 分 后 
的 数组 ， 其 代码 如 下 : 
<?php 
$arr = array("PHP 编程 ","Java 编程 "."C# 编 程 ""ASPNET 编程 "); /定义 数组 
echo" 原 数组 : ": 
print_r($arr): /打印 数组 
echo "<br><br>"; 
echo " 拆 分 后 的 数组 : “ 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
Pprint_r(array_chunk($arr,2))."<br>"; // 拆 分 数组 


?> 


(2) 将 该 文件 存储 于 \MR\02\139 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.113 所 示 。 
秘笈 心 法 


心 法 领悟 139: 使 用 array_chunkO 函 数 的 注意 事项 。 
使 用 array_chunkO 函 数 拆 分 的 数组 ， 最 后 一 个 数组 的 单元 数目 可 能 会 少 几 个 。 
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实例 140 


力 实例 说 明 
通过 for 语句 可 以 遍历 数组 ,下 面 通过 另外 一 种 方法 来 遍历 数组 。 本 实例 通过 list0 和 each0 函 数 实现 遍历 数 


组 ， 运 行 结果 如 图 2.114 所 示 。 


[EL 
Array ( [1] .=> PR e] => PHP 编 程 [0] 二 > 0 >0) 
Array ( [1] = >,Java value] => Java 编 程 [0] 丘 > j=> 塌 


Array ( [1] => 6# [value} => C# 编 程 [0] = 为 2 区 Ba>2) 
Array ( [1] => ASP.NET 编 程 "fyalue] => ASP.NE ‘0] > 区 
[key] => 3) 


图 2.114 遍历 数组 


图 关键 技术 


遍历 数组 的 方法 有 很 多 ， 除 了 使 用 foreach 语句 外 ， 还 可 以 通过 list0 和 each0 函 数 配合 使 用 来 实现 ， 其 相关 
语法 如 下 : 

list0 函 数 把 数组 中 的 值 赋 给 一 些 变量 。 与 array0 函 数 类 似 ， 其 不 是 真正 的 函数 而 是 语言 结构 。list0 函 数 仅 
能 用 于 数字 索引 的 数组 ， 且 数字 索引 从 0 开始， 其 语法 如 下 : 


a 

参数 mixed 为 被 赋值 的 变量 名 称 。 

each() 函 数 ， 返 回 数组 中 当前 指针 位 置 的 键 名 和 对 应 的 值 ， 并 向 前 移动 数组 指针 。 键 值 对 被 返回 为 4 个 单 
元 的 数组 ， 键 名 为 0、1、key 和 value。 单 元 0 和 key 包含 有 数组 单元 的 键 名 ，1 和 value 包含 有 数据 ， 其 语法 


ee 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 遍 历数 组 ”按钮 时 ， 首 先 定义 数组 变量 并 为 其 赋值 ， 然 后 通过 list0 和 
each0 函 数 实现 数组 遍历 并 输出 结果 ， 其 代码 如 下 : 

< 


php 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
$foo = array("PHP 编程 "."JAVA 编程 ""C# 编 程 ""ASPNET 编程 "); /定义 数组 
for($a = 0:$a < count($foo):$at+){ // 定 义 循环 
Print_r(list($name, $value)=each($fo0)): // 打 印 数组 


} 


2 
(2) 将 该 文件 存储 于 \MR\02\140 文件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.114 所 示 。 
国 秘笈 心 法 


心 法 领悟 140: 使 用 list0 和 eachO 函 数 的 注意 事项 。 
list0 函 数 只 能 用 于 数字 索引 的 数组 。 如 果 内 部 指针 越过 了 数组 的 末端 ， 则 each0 函 数 返回 FALSE。 
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2.11 日 期 和 时 间 


对 日 期 和 时 间 进 行 操作 的 程序 无 处 不 在 ， 特 别 是 在 基于 Web 的 应 用 程序 中 ， 如 表单 提交 的 时 间 、 用 户 登 录 
的 时 间 、 数 据 库 中 数据 的 更 新 和 删除 的 时 间 等 。 想 要 记录 这 些 操作 执行 的 时 刻 ， 就 需要 通过 日 期 和 时 间 来 完成 。 
日 期 和 时 间 在 人 们 的 生活 中 必 不 可 少 ， 同 样 ， 在 互联 网 中 也 是 非常 重要 的 。 


| 
图 实例 说 明 


系统 的 当前 时 间 受 时 区 限制 ， 默 认 情 况 下 是 格林 威 治 时 间 。 用 户 正 确 取得 本 地 时 间 是 很 重要 的 。 本 实例 通 
过 date0 函 数 获 取 系统 的 当前 时 间 ， 运 行 结果 如 图 2.115 所 示 。 


EC 


10:03:34 


2.115 设置 系统 的 当前 时 间 


力 关键 技术 


因为 在 PHP 语言 中 , 日 期 时间 函 数 依赖 于 服务 器 的 地 区 设置 , 而 PHP 默认 设置 的 是 标准 的 格林 威 治 时 间 
( 即 采 用 的 是 零 时 区 ) ， 所 以 ， 如 果 没有 对 PHP 的 时 区 进行 设置 ， 那 么 使 用 日 期 、 时 间 函 数 获取 的 将 是 英国 伦 
敦 本 地 时 间 《〈 即 零 时 区 的 时 间 ) 。 

这 也 是 对 PHP 的 时 区 进行 设置 的 原因 ， 因为 如 果 不 设置 正确 的 时 区 ,那么 PHP 的 日 期 、 时 间 函 数 就 获取 不 
到 正确 的 当地 时 间 。 例 如， 以 东 八 区 为 例 ， 如 果 当 地 使 用 的 是 北京 时 间 ， 那么 在 没有 对 PHP 的 时 区 进行 设置 时 ， 
获取 的 时 间 就 将 比 北京 时 间 少 8 个 小 时 。 

更 改 PHP 语言 中 的 时 区 设置 有 如 下 两 种 方法 。 

(1) 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone =” 选 项 ， 去 掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当 
地 所 在 时 区 使 用 的 时 间 。 修 改 内容 如 图 2.116 所 示 。 

例如 ， 如 果 当 地 所 在 时 区 为 东 八 区 ， 那 么 就 可 以 设置 “date.timezone =” 的 值 为 PRC、Asia/Hong_ Kong、 
Asia/Shanghai (上 海 ) 或 者 Asia/Urumqi (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


是 phpjini - 记事 本 =| 口 | | 
文件 加 


; Defines the default tinezone used by the 


date functions 
ate -tinezone 


2.116 设置 PHP 的 时 区 


设置 完成 后 ， 保 存 文件 ， 重 新 启动 Apache 服务 器 。 
(2) 在 应 用 程序 中 , 在 日 期 、 时 间 函 数 之 前 使 用 date_default timezone_setO 函 数 就 可 以 完成 对 时 区 的 设置 。 
date_default_timezone_set0 函 数 的 语法 如 下 : 


date_default_timezone_set(timezone): 


参数 timezone 为 PHP 可 识别 的 时 区 名 称 ， 如 果 无 法 识别 ， 则 系统 采用 UTC 时 区 。 
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例如 , 设置 北京 时 间 可 以 使 用 的 时 区 包括 PRC (中 华人 民 共 和 国 ) 、Asia/Chongqing (重庆 ) 、Asia/Shanghai 
(上 海 ) 和 Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 区 名 称 是 等 效 的 。 


图 设计 过 程 


新 建 index.php 文件 ， 当 单 击 “ 地 区 时 间 ” 按 钮 时 ， 首 先 为 当前 PHP 服务 时 间 设 置 时 区 ， 并 通过 switch 语 
名 根据 地 址 栏 传递 参数 的 不 同 ， 通 过 date(O) 函 数 获 取 不 同 国家 和 地 区 的 时 间 ， 其 代码 如 下 : 


hp 
if($_POST[sub){ 


case "英国 "; 
echo (date("H")-8).":".date(™i:s"); 
break: 


case "日 本 "; 
echo(date("H")+1).":".date("i:s"): 
break: 


case "开罗 "; 
echo(date("H")-6).":".date("i:s"); 
break: 

case "莫斯科 "; 
echo(date("H")-5).":".date("i:s"); 
break; 


} 


2 


国 秘笈 心 法 


心 法 领悟 141: 知识 扩展 。 


// 通 过 POST 方式 传递 参数 
// 设 置 时 区 

/| 条 件 语句 

// 如 果 是 中 国 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 英国 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 日 本 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 开罗 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 莫斯科 
/| 输出 时 间 

// 结 束 语句 


本 实例 只 是 简单 地 向 用 户 介绍 时 区 及 不 同 地 区 相差 的 小 时 数 ， 在 实际 开发 中 不 能 对 时 间 单 纯 地 进行 算术 运 


算 ， 需 要 使 用 关键 技术 中 提供 的 方法 对 PHP 的 时 
实例 142 


力 实例 说 明 


区 进行 设置 。 


趣味 指数 : 请 请 请 斌 | 


将 日 期 转换 为 时 间 戳 是 将 时 间 进 行 数学 运算 的 重要 手段 。 本 实例 通过 time0 函 数 实现 将 日 期 和 时 间 转 换 为 


时 间 戳 ， 运 行 结 果 如 图 2.117 所 示 。 


当前 时 间 : 


2.117 将 日 期 和 时 间 转 换 为 时 间 戳 


图 关键 技术 


获取 系统 UNIX 时 间 戳 的 方法 有 很 多 ， 使 用 ttme0 函 数 是 比较 常用 的 一 种 方法 ，time0) 函 数 的 语法 如 下 : 


inttime ( void ): 
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该 函数 没有 参数 ， 返 回 值 为 UNIX 时 间 戳 的 整数 值 。 
图 设计 过 程 
创建 index.php 文件 。 首 先 ， 设置 PHP 的 时 区 为 中 国 上 海 ， 然 后 ， 利 用 time0 函 数 获 取 当 前 的 时 间 稚 ， 并 通 
过 echo 语句 输出 时 间 戳 ， 其 代码 如 下 : 


<?php 

date_default_timezone_set("Asia/ShangHai"); // 设 置 时 区 

echo "当前 时 间 : ".date('Y-m-d H:i's): /取得 当前 时 间 

ee "<br> 转 换 成 时 间 惟 为 : "time0: // 转 换 为 时 间 才 
| | 秘笈 心 法 


心 法 领悟 142: 知识 扩展 。 
将 当前 日 期 和 时 间 转 换 为 时 间 戳 的 方法 有 很 多 ， 下 面 通过 strtotimeO 函 数 实现 本 例 功 能 ， 代 码 如 下 : 


<Iphp 
date_default_timezone_ set("Asia/ShangHai"); /设置 时 区 
echo "当前 时 间 : ".date('Y-m-d H:i:s); /设置 当前 日 期 和 时 间 
echo “转换 时 间 惟 为 : "strtotime("now"); /转换 时 间 惟 
2> 
2 
实例 143 : . | 
趣味 指数 : 克 友 友 友 | 


力 实例 说 明 


在 PHP 程序 设计 中 ， 日 期 和 时 间 是 具有 一 定格 式 的 ， 例 如 ， 今 天 是 一 年 的 第 多 少 天 等 。 本 实例 应 用 date0 
函数 通过 传 入 参数 不 同 实现 日 期 和 时 间 的 格式 化 ， 运 行 结果 如 图 2.118 所 示 。 


图 2.118 日 期 和 时 间 的 格式 化 


力 关键 技术 

本 实例 通过 date0 函 数 实现 日 期 和 时 间 的 格式 化 ， 详 细 说 明 请 参见 实例 035。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 设 置 PHP 的 时 区 为 中 国 上 海 。 然 后 ， 利 用 向 date0 函 数 中 传递 的 参数 不 同 实现 
lh 并 输出 格式 化 后 的 信息 ， 其 代码 如 下 : 


局 default_ timezone_set("Asia/ShangHai"): // 设 置 时 区 
echo "当前 时 间 : "date(Y 年 月 d 日 了 点 i 分 s 秒 A)."<br>": /格式 化 日 期 和 时 间 


echo "本 月 有 ".date(t)." 天 .<br> 今 天 是 一 周 的 第 ".date(w)." 天 ,是 一 年 的 第 ".date(z)." 天 ": 


?> 
(2) 将 该 文件 存储 于 \MR\02\143 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.118 所 示 。 
力 秘笈 心 法 
心 法 领悟 143: 知识 扩展 。 
date0 函 数 还 有 很 多 其 他 的 参数 ， 熟 悉 这 些 参 数 的 使 用 可 以 在 使 用 格式 化 时 间 、 日 期 上 事半功倍 ， 具 体 参数 
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说 明 请 参见 实例 035。 


实例 144 


力 实例 说 明 
在 PHP 语言 中 ， 要 完成 对 两 个 时 间 大 小 的 比较 ， 必 须 先 将 时 间 转 换 为 时 间 戳 ， 可 以 通过 strtotime0 函 数 完 
成 。 本 实例 应 用 strtotime0 函 数 对 两 个 固定 的 时 间 进 行 比较 ， 其 运行 结果 如 图 2.119 所 示 。 


图 2.119 比较 时 间 的 大 小 


图 关键 技术 


PHP 中 应 用 strtotime0 函 数 将 任何 英文 文本 的 日 期 解析 为 UNIX 时 间 戳 ， 其 值 为 相对 于 now 参数 给 出 的 时 
间 ， 如 果 没 有 提供 此 参数 则 用 系统 当前 时 间 ， 此 时 与 实例 142 中 的 time0 函 数 相同 。strtotime0 函 数 的 语法 如 下 : 

int strtotime ( string time [, int now] ): 

该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如 果 参 数 time 的 格式 是 相 
对 时 间 ， 其 对 应 的 时 间 就 是 参数 now 来 提供 的 ， 当 没有 提供 参数 now 时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 
失败 ， 则 返回 FALSE。 在 PHP 5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 编 写 form 表单 并 设置 当前 时 区 为 中 国 上 海 ， 当 单 击 “ 日 期 比较 ”按钮 时 ， 
运用 strtotime0 函 数 获取 两 个 不 同时 间 点 的 时 间 戳 ， 并 进行 求 差 运算 。 最 后 ， 输 出 相关 提示 ， 其 代码 如 下 : 
<?php 


echo "<form action=" method= post>": /| 输出 表单 

echo "<input type='submit name='sub' value=' 日 期 比较 >"; 

echo "</form>"; 

date_default_timezone_set("Asia/ShangHai"): /设置 时 区 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
Stime=date("Y 年 m 月 d 日"); /取得 当前 日 期 
S$time_ 1=time0; // 取 得 当前 时 间 玲 
Stime 2 = strtotime("27 June 2014"): /取得 固定 日 期 的 时 间 戳 
if($time 2<S$time_ 1){ /时 间 翼 比较 


echo $time." 比 2014 年 6 月 27 日 大 "; 
Jelse{ 

echo $time." 比 2014 年 6 月 27 日 小 "; 
} 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\144 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.119 所 示 。 
国 秘 稚 心 ; 


心 法 领悟 144: 使 用 strtotime0 函 数 的 相关 说 明 。 

strtotimeO 函 数 预 期 接受 一 个 包含 美国 英语 日 期 格式 的 字符 串 ， 并 尝试 将 其 解析 为 UNIX 时 间 戳 《 自 
January 1 1970 00:00:00 GMT 起 的 秒 数 ) ， 其 值 相对 于 now 参数 给 出 的 时 间 ， 如 果 没 有 提供 此 参数 则 用 系统 
当前 时 间 。 
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实例 145 


rn FI. 
实例 说 明 
计算 考试 时 间 程 序 是 单纯 地 将 两 个 时 间 点 的 时 间 戳 做 算术 运算 。 本 实例 通过 您 用 时 5 和 答题 

time() 函 数 实现 考试 时 间 的 计算 ， 运 行 结果 如 图 2.120 所 示 。 图 2.120 计算 考试 时 间 

力 关键 技术 


本 实例 的 关键 点 是 tmeO 函 数 的 灵活 运用 。 当 单 击 “ 开 始 答题 ”按钮 时 ， 将 time0O 函 数 获取 的 时 间 戳 存储 到 
SESSION 变量 中 ， 当 单 击 “ 答 题 完毕 ”按钮 时 ， 再 次 通过 time(O) 函 数 获取 系统 的 当前 时 间 戳 。 当 前 时 间 戳 减 去 
开始 定义 的 时 间 戳 ， 就 是 考试 所 用 时 间 。 

力 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 编写 form 表单 并 设置 两 个 提交 按钮 ， 当 每 个 按钮 被 单 击 后 ， 利 用 SESSION 
变量 保存 此 时 的 时 间 玲 并 进行 求 差 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 

<php 


echo "<form action =" method =post>": /输出 表单 
echo "<input type = submit name='sub’ value=' 开 始 答题 >&nbsp;<input type='submit name='sub_l'value = 答题 完毕 >"; 
echo "</form>"; 
if($_POST[sub){ /通过 POST 方式 传递 参数 
Stime = time(); // 取 得 当前 时 间 玲 
$_SESSION['time'] = $time; /将 时 间 戴 保存 在 SESSION 中 
echo "<script>alert(' 单 击 确定 开始 答题 ");:</script>"; /| 输出 提示 
} 
这 $_ POST[sub_1]){ // 通 过 POST 方式 传递 参数 
iflisset($_SESSION['time']){ // 判 断 SESSION 是 否 存在 
echo "您 用 时 ".(time0-$_ SESSION['time])." 秒 答题 ": /输出 结果 
session_destroy(): /| 销毁 SESSION 
jelsef // 否 则 输出 提示 


echo "<script>alert( 您 还 没有 答题 无 法 结束 ， 请 先 答题 ! ):location href~'index.php'</script>"; 
} 
} 


> 
(2) 将 该 文件 存储 于 \MR\02\145 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.120 所 示 。 
力 秘笈 心 法 


心 法 领悟 145: 知识 扩展 。 
本 实例 运用 SESSION 机 制 保存 考试 的 开始 时 间 ， 然 后 完成 考试 时 间 的 计算 。 有 关 SESSION 机 制 的 详细 讲 
解 请 参考 本 书 第 5 章 的 内 容 。 


本 | 


四 实例 说 明 


倒计时 功能 的 实现 同样 也 是 将 时 间 戳 做 算术 运算 。 本 实例 应 用 strtotime0 函 数 实现 倒计时 程序 ,运行 结果 如 
图 2.121 所 示 。 
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2.121 倒计时 


图 关键 技术 
本 实例 的 关键 点 是 strtotime0) 函 数 的 灵活 运用 ， 详 细 说 明 参 见 实例 144。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 设 置 当前 时 区 为 中 国 上 海 。 首 先 ， 利 用 time0 函 数 取 得 当前 时 刻 的 时 间 惟 并 保存 
在 变量 中 。 然 后 ， 利 用 strtotimeO 函 数 取 得 2011 年 1 月 1 日 的 时 间 戳 并 保存 在 变量 中 ， 将 两 个 时 间 改 进行 求 差 
ne 其 代码 如 下 : 


default timezone_set("Asia/ShangHai"); /设置 时 区 

echo "当前 时 间 : "date(Y 年 耳 月 d 日 吾 点 i 分 s 秒 )"<br>"; /输出 当前 日 期 

Stime = time(); /取得 当前 时 间 戳 
Stime r= strtotime("1 January 2016"); /取得 指定 日 期 的 时 间 截 


echo " 距 2016 年 元 旦 还 有 <b style= colorred;>".ceil(((Stime r - $time)/(3600*24)))."</b> 天 "; /输出 
了 
(2) 将 该 文件 存储 于 \MR\02\146 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.121 所 示 。 
国 秘笈 心 法 


心 法 领悟 146: 时 间 比 较 的 原理 。 
通过 上 面 几 个 实例 用 户 应 该 明白 ， 其 实 所 有 的 时 间 比 较 归根 结 底 都 是 时 间 戳 的 比较 ， 所 以 掌握 时 间 稚 是 十 
分 重要 的 。 


- 一 一 a 
力 实例 说 明 


闹钟 是 人 们 生活 中 经 常 使 用 的 一 个 小 工具 ， 它 会 在 指定 时 间 叫 你 起 床 。 在 Web 程序 中 ， 也 可 以 应 用 这 个 原 
理 开 发 一 个 “网 页 闹钟 ”， 提 示 用 户 在 指定 的 时 间或 者 时 间 段 内 要 做 什么 工作 。 本 实例 通过 mktimeO) 函 数 实现 
网 页 闹钟 程序 ， 运 行 结 果 如 图 2.122 所 示 。 


图 2.122 网 页 闹钟 


图 关键 技术 


PHP 中 , 应 用 mktimeO 函 数 将 一 个 时 间 转 换 成 UNIX 的 时 间 戳 值 。mktimeO 函 数 根据 给 出 的 参数 返回 UNIX 
时 间 戳 。 时 间 戳 是 一 个 长 整数 ， 包 含 从 UNIX 纪元 到 给 定时 间 的 秒 数 。mktime0 函 数 的 语法 如 下 : 


int mktime ( [int hour [. int minute [. int second [, int month [, int day [. int year [. int is_dst]]]]]]] ): 
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mktime() 函 数 的 参数 说 明 如 表 2.8 所 示 。 
表 2.8 mktime() 函 数 的 参数 说 明 


参数 说 明 

hour 小 时 数 

Iminute 分 钟 数 

Second 秒 数 〈 一 分 钟 之 内 ) 

month 月 份 数 

day 天 数 

year 年 份 数 ， 可 以 是 2 位 或 4 位 数字 ，0~69 对 应 于 2000~2069，70~100 对 应 于 1970~2000 
is_dst 在 夏令 时 可 以 被 设 为 1， 如 果 不 是 则 设 为 0;， 如 果 不 确定 是 否 为 夏令 时 ， 则 设 为 -1 默认 值 ) 


图 设计 过 程 
(1) 创建 index.php 文件 。 首 先 定义 PHP 时 区 为 中 国 上 海 ， 然 后 编写 form 表单 ， 通 过 mktime0 函 数 实现 
获取 当前 的 时 间 戳 ， 其 代码 如 下 : 


<?php 
echo "<table border="1' bordercolor=#FF0000' cellspacing="0' align='center><tr><td>"; /输出 表格 
echo "<h2 style='color:#0033FF> 曾 钟 程序 </h2>"; /输出 标题 
date_default_timezone_set("Asia/ShangHai"); /设置 时 区 
echo "<h6 style='color:red> 今 天 是 ".date("Y-m-d H:i:s")."</h6>"; // 输 出 当前 时 间 
echo "<form action=" method= post>": // 输 出 表单 
echo "<input type='text name='textl' size='2> 年 <input type='text name='text2' size='2> 月 "; 
echo "<input type='text name='text3' size=2> 日 <br><input type='text name='text4' sizc= 2> 时 ": 
echo "<input type='text’ name='text$' size="2> 分 <input type='text name='text6' size=2> 秒 <br>"; 
echo "<input type='submit’ name='sub' value= 定 时 >"; 
echo "</form>"; 
$a=$_POST[text1]; // 取 得 文本 框 内 容 
$b=$_POST[text2]; // 取 得 文本 框 内 容 
$c =$_POST[text3]: // 取 得 文本 框 内 容 
$d=$_POST[text4]: // 取 得 文本 框 内 容 
$e =$_POST[text5]: // 取 得 文本 框 内 容 
$f=$_POST[text6]: // 取 得 文本 框 内 容 
Stime = date(mktime($d, $e, Sf $b. $c, $a)): /获取 时 间 戳 
$_SESSION[time] = Stime: /保存 在 SESSION 中 
这 $_ POST[sub]){ /通过 POST 方式 传递 参数 
echo"<script>window.location.href="in.php';</script>"; // 跳 转 
echo "</td></tr></table>": 
> 
(2) 创建 n.php 文件 ， 其 代码 如 下 : 
<?php 
date_default_timezone_set("Asia/ShangHai"): /设置 时 区 
S$time 1 = time(); /取得 当前 时 间 戳 
这 $_SESSION[time] < $time_1){ 1/ 判断 条 件 
echo "<script>alert(' 时 间 一 去 不 复 返 ):location href='index.php'</script>": // 输 出 提示 
Jelse{ 
if($_SESSION['time] — Stime 1){ // 判 断 条 件 
echo "<script>alert( 今 天 是 XXX 生日 ):</script>": // 输 出 提示 
Jelse{ /输出 提示 


> 


echo "距离 XXX 的 生日 还 有 ".ceil((($_SESSION['time']-$time_1)/(3600*24)))." 天 ": 


站 
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心 法 领悟 147: 不 同 版 本 的 操作 平台 对 UNIX 时 间 戳 的 支持 。 

PHP 为 UNIX 时 间 戳 的 处 理 提供 各 种 函数 。 到 目前 的 PHP 版 本 为 止 ， 由 于 任何 已 知 Windows 版 本 以 及 一 
些 其 他 系统 均 不 支持 负 的 时 间 戳 ， 因 此 在 Windows 中 无 法 表示 1970 年 1 月 1 日 之 前 的 时 间 。 因 为 目前 UNIX 
时 间 戳 是 以 32 位 二 进 制 表示 的 ， 其 范围 为 -2147483648 ~ +2147483647) ， 因 此 ， 目 前 UNIX 时 间 稚 可 表示 的 最 
大 时 间 为 2038 年 1 月 19 日 3 点 14 分 7 秒 ， 该 时 刻 时 间 惟 为 2147483647， 对 于 该 时 刻 之 后 的 时 间 ， 需 要 扩展 
表示 UNIX 时 间 戳 的 二 进 制 位 数 。 


实例 148 


力 实例 说 明 

在 百度 中 ， 当 执行 一 个 查询 操作 时 ， 获 取 到 查询 结果 后 页 面 中 就 会 出 现 一 行文 字 ， 提 示 根 据 关 键 字 搜索 到 
多 少 个 结果 ， 以 及 搜索 所 用 的 时 间 。 这 个 时 间 就 是 程序 在 执行 该 搜索 时 所 用 的 时 间 ， 那 么 它 是 如 何 实现 的 呢 ? 
下 面 就 模仿 它 来 做 一 个 计算 程序 运行 时 间 的 小 程序 ， 其 运行 结果 如 图 2.123 所 示 。 
下 高 2016 年 奥运 会 乔 蕊 还 有 450 闫 170[ 


倒计时 程序 的 运行 时 间 为 0.000311036804312 秒 


图 2.123 计算 程序 运行 时 间 


图 关键 技术 


本 实例 的 关键 点 是 strtotime() 函 数 的 使 用 ， 其 原理 是 : 首先 在 执行 查询 操作 之 前 定义 一 个 时 间 ， 将 其 精确 到 
微 秒 ， 然 后 执行 查询 操作 ， 接 着 在 查询 功能 执行 完毕 后 再 次 获取 一 个 时 间 ， 同 样 精确 到 微 秒 ， 应 用 后 获取 的 时 
间 减 去 最 初 获 取 的 时 间 ， 就 是 本 次 查询 所 用 的 时 间 。 


力 设计 过 程 
创建 index.php 文件 。 首 先 定义 nan_time0 函 数 ， 获 取 系 统 当前 的 时 间 戳 。 然 后 调用 run_time0 方 法 ， 获 取 当 


前 时 间 戳 ， 接 着 运行 程序 。 最 后 ， 再 次 调用 run_time0 函 数 ， 获 取 系统 当前 时 间 ， 并 且 输 出 差 值 ， 获 取 程序 的 运 
行 时 间 ， 其 代码 如 下 : 


<?php 

请 ”声明 ran_time0 函 数 

通过 microtime() 函 数 获取 当前 时 间 的 微 秒 数 和 时 间 玲 

应 用 explode0 函 数 将 mierotime0 函 数 返回 的 字符 串 进行 分 隔 ， 返 回 一 个 数组 
包括 两 个 元 素 ， 一 个 元 素 是 当前 时 间 的 微 秒 数 ， 另 一 个 是 当前 时 间 的 时 间 戳 
应 用 list0 函 数 将 explode0 函 数 返回 的 数组 值 赋 给 指定 的 变量 

最 后 ， 获 取 两 个 变量 值 的 和 

4 


function run_timeO{ 
list($msec. $sec) = explode(" ", microtime()): // 使 用 explode0 函 数 返 回 两 个 变量 
retum ((float)$msec + (float)$sec): /返回 两 个 变量 的 和 
} 
$start_time = run_time(); // 第 一 次 运行 un_time0 函 数 
记 ”运行 PHP 代 码 段 */ 
Stimel = strtotime(date( "Y-m-d")):; // 当 前 的 系统 时 间 
Stime2 = strtotime("2016-08-05"); // 奥 运 会 的 开幕 时 间 
$sub2 = ceil(($time2 - Stime1) /86400): 1/(60 秒 *60 分 *24 小 时 ) 秒 /天 
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echo "距离 2016 年 奥运 会 开幕 还 有 <font color=red>$sub2 <Jfont> 天 !: 


话 市 于 于 再 刘 于 本 于 本 本 素 本 本 


Send_time = run_time(); // 再 次 运行 run_time0 函 数 
?> 

<!-- 输出 差 值 ， 获 取 程序 的 运行 时 间 --> 

倒计时 程序 的 运行 时 间 为 <font color=blue> <?php echo ($end time - $start_time); ?> </font> 秒 

be 


国 秘笈 心 法 


心 法 领悟 148: 在 PHP 中 应 用 日 期 、 时 间 函 数 时 的 注意 事项 。 

加 ”在 配置 PHP 时 , 进行 正确 的 时 区 设置 , 这 样 就 不 会 在 输出 时 间 时 出 现 输出 结果 与 当地 时 间 不 符 的 问题 。 

回 ”在 正确 地 配置 了 PHP 的 时 区 之 后 ， 就 要 使 用 日 期 、 时 间 函 数 获 取 日 期 、 时 间或 者 对 应 的 时 间 惟 ， 那 么 
必须 明确 一 个 日 期 、 时 间 在 不 同 的 操作 系统 中 的 有 效 范围 ， 避 免 出 现 获取 超出 范围 的 日 期 、 时 间 数 据 
的 现象 。 

回 ” 有 效 的 时 间 戳 范围 是 格林 威 治 时 间 1901 年 12 月 13 日 20:45:54~2038 年 1 月 19 日 03:14:07( 此 范围 符 

合 32 位 有 符号 整数 的 最 小 值 和 最 大 值 ) 。 

在 Linux 系统 中 此 范围 限制 为 1901 年 12 月 13 日 -2038 年 1 月 19 日 。 

在 Windows 系统 中 此 范围 限制 为 1970 年 1 月 1 日 -2038 年 1 月 19 日 。 

在 通过 日 期 、 时 间 函 数 获取 日 期 、 时 间或 者 时 间 戳 时， 如 果 没 有 指定 时 间 戳 ， 那 么 获取 的 是 本 地 时 间 。 


图 回回 
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Web 页 面 交 互 


第 3 章 Web 页 面 交 互 


3.1 获取 表单 元 素 的 值 


获取 表单 元 素 提交 的 值 是 表单 应 用 中 最 基本 的 操作 方法 , 通过 获取 表单 元 素 提交 的 值 可 以 实现 很 多 的 功能 
例如 ， 添 加 用 户 注 册 信息 、 提 交 用 户 登录 信息 、 添 加 学 生 详细 信息 等 。 下 面 通过 具体 实例 来 介绍 获取 表单 元 素 
提交 的 值 在 PHP 中 的 应 用 。 


力 实例 说 明 


论坛 是 许多 网 站 不 可 或 缺 的 模块 之 一 ， 它 为 人 们 相互 之 间 进 行 各 种 沟通 和 交流 提供 了 一 个 空间 。 设 计 论坛 
模块 的 第 一 个 步骤 就 是 设计 论坛 登录 界面 ， 让 用 户 根据 自 己 注册 的 用 户 名 和 密码 登录 论坛 。 在 本 例 中 笔者 设计 
了 一 个 简单 的 论坛 登录 界面 ， 效 果 如 图 3.1 所 示 。 


3.1 登录 界面 


图 关键 技术 


在 设计 论坛 登录 界面 时 ， 主 要 采用 表格 标签 进行 界面 布局 ， 设 计 一 个 3 行 2 列 的 表格 ， 如 图 3.2 所 示 。 


用 户 志 了 
密 码 | i 


图 3.2 利用 表格 标签 布局 


这 样 , 一 个 论坛 登录 界面 的 轮廓 就 形成 了 。 接 下 来 还 需要 为 表格 设置 背景 图 像 , 利用 表格 标签 的 background 
属性 设置 即 可 ， 代 码 如 下 : 

<table width="392px" height="249px" align="center"><tr><td background="pic/tablebk jpe"> 
图 设计 过 程 

(1) 利用 Dreamweaver 开发 工具 创建 一 个 动态 PHP 页 ， 将 其 保存 为 index.php。 

(2) 添加 一 个 表单 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 调整 表格 各 行 的 高 度 和 列 的 宽度 。 

(3) 设置 表格 的 align 属性 为 center， 使 得 表格 在 表单 中 始终 居中 显示 。 

(4) 向 表格 单元 格 中 输入 用 户 名 称 和 密码 信息 ， 并 添加 文本 字段 和 按钮 。 

(5) 设置 “密码 ”文本 字段 的 类 型 (type) 属性 为 password， 使 其 以 掩 码 的 形式 隐藏 真实 密码 。 

(6) 实例 主要 代码 如 下 : 


q 
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<form action="" method="post"> 
<table align="center"> 
<tr><td> 用 户 名 <itd><td><input type="text" name="te" size="20" /></td></tr> 
<tr><td> 密 &nbsp;&nbsp; 码 </td><td><input type="password" name="tex" size="22" /></td></tr> 
<tr><td align="left"><input class="two"type="submit" name="sub" valuec="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" /></td> 
<td align="left"><input class="three" type="reset" name="res" value="&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp:" /></td></tr> 
</table> 
</form> 


秘笈 心 ; 


心 法 领悟 149: 密码 框 与 文本 字段 宽度 不 一 致 的 解决 方案 。 

许多 初学 人 员 都 会 遇 到 这 种 情况 ， 在 设计 时 密码 框 的 宽度 与 文本 字段 宽度 相同 ， 但 是 在 浏览 器 中 显示 则 不 
相同 。 解决 方 法 是 在 密码 框 和 文本 字段 中 指定 统一 的 CSS 样式 , 即 设置 class 属性 。 在 PHP 页 面 中 添加 一 个 CSS 
样式 : 

<style type="text/css"> 

i 

width : 200px; 


这 样 ， 问 题 就 解决 了 。 


高 级 
趣味 指数 : 庚 庚 育 商 


实例 150 


力 实例 说 明 


许多 大 型 网 站 为 了 吸引 用 户 ， 会 分 配 一 些 空间 供用 户 使 用 。 例 如 ， 大 家 经 常 使 用 的 电子 邮箱 、QQ 个 人 空 
间 等 。 为 了 能 够 让 用 户 在 个 人 空间 中 放置 自己 的 内 容 ， 网 站 都 会 提供 文件 、 图 片 等 信息 的 上 传 功能 。 例如 在 QQ 
个 人 空间 中 ， 用 户 可 以 上 传 自己 的 照片 ， 供 好 友 欣 赏 。 本 实例 利用 文件 域 实 现 图 片 的 上 传 功能 ， 效 果 如 图 3.3 
所 示 。 


se 


不 断 升级 的 炉 心 开发 资源 库 ， 为 您 开发 提供 最 系统 、 最 全 面 、 最 权 左 的 开发 撤 


档 和 矶 用 文章 ， 解 决 业 技 术 坦 不 要 .技术 
A 不 全 面 、 挝 术 无 应 用 委 开 发 难 胡 和 困扰 。 
[| 


图 3.3 可 以 上 传 图 片 的 表单 


力 关键 技术 


在 本 例 中 ， 实 现 照片 上 传 的 主要 方式 是 利用 文件 域 让 用 户 加 载 本 地 文件 ， 然 后 应 用 PHP 函数 
move_uploaded_file0 实 现 文件 的 上 传 ， 效 果 如 图 3.4 所 示 。 


Fampowampo\htdocs Wh Ea 3 


图 3.4 文本 域 加 载 本 地 文件 


@ 
mw 
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move uploaded file() 函 数 可 将 上 传 的 文件 移动 到 新 位 置 ， 其 语法 如 下 : 


bool move_uploaded file ( string filename, string destination ); 
参数 说 明 : 

string filename: 指定 的 文件 是 合法 的 上 传 文件 。 
string destination: 定义 上 传 文件 的 名 称 。 


图 设计 过 程 
(1) 创建 动态 PHP 文件 ， 命 名 为 index.php。 


(2) 添加 一 个 表单 ， 将 type 属性 设置 为 file， 代码 如 下 : 


<form action="" method="post" enctype="multipart /form-data"> 
<input type="file" name="upfile" size="20" /> 


<input class="two"type="submit" name="sub" value="&nbsp:é&nbsp;éenbsp:&nbsp; Genbsp;&nbsp;éenbsp:" /> 


</form> 
(3) 利用 <table> 标 签 编写 网 页 框架 。 
(4) 利用 编码 实现 上 传 功能 ， 核 心 代码 如 下 : 


<php 
if($_POST[sub){ 
if($_FILES['upfile]['name] — "){ 
echo "<script>alert( 上 传 内 容 为 空 );:</seript>"; 
jslsef 
Sinfo =$_FILES['upfile]: 
ifSinfof'size]> 0 && Sinfo['size] < 1024 * 8000){ 
Sdir = "upfiles/"; 
Sname = $info['name']: 
Srand = rand(0,10000000); 
Sname = $rand.date(YmdHis) $name: 
Spath = upfiles/,Sname; 
(tis_dir($dir)){ 
mkdir($dir): 
} 


Smove = move_ uploaded_file(Sinfo[tmp_name].Spath; 


if($move — true){ 
echo "<script>alert(' 上 传 文件 成 功 ):</script>"; 
} 
jelse{ 
echo "<script>alert( 上传 文件 过 大 ");</script>"; 
} 


} 
?> 


国 秘笈 心 法 
心 法 领悟 150: 解决 上 传 文件 重 名 问题 。 


// 单 击 “ 上 传 ”按钮 
1/ 判断 上 传 文件 名 称 是 否 为 空 


// 将 上 传 文件 信息 保存 在 数组 中 
1/ 判断 上 传 文件 的 大 小 

// 定 义 变量 

1/ 设 定 文件 名 称 


1/ 判断 文件 夹 是 否 存在 ， 如 果 不 存在 则 创建 一 个 文件 夹 


// 将 上 传 文件 移动 到 指定 位 置 


如 果 用 户 建立 个 人 网 站 ， 人 允许 他 人 上 传 文件 到 服务 器 中 ， 但 是 每 一 个 浏览 网 站 的 用 户 并 不 知道 服务 器 中 是 
否 存 在 与 即将 上 传 的 文件 重 名 的 文件 。 大 家 都 知道 ， 在 Windows 系统 下 ， 同 一 个 文件 夹 中 不 允许 两 个 同名 文件 
的 存在 ， 这 就 使 得 用 户 上 传 的 文件 名 必须 是 独一无二 的 。 笔 者 为 上 传 文件 的 名 称 设置 了 如 下 代码 : 


Sname = $info['name']; 

Srand = rand(0.10000000): 

Sname = Srand date(YmdHis).Sname: 
$path = "upfiles/.$name: 


在 一 般 情况 下 ， 这 样 可 以 避免 上 传 文件 重 名 的 现象 


// 设 定 文件 名 称 
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力 实例 说 明 
POST 方法 是 提交 表单 元 素 的 方法 之 一 ， 是 程序 员 提交 表单 的 主要 途径 。 运 行 本 实例 ， 效 果 如 图 3.5 所 示 。 


三 

从 软件 工 各 9 入 习 、 玫 入 大 目的 开发 届 序 ， 其 统 、 全 画 地 介绍 项 目的 开 并 3 
对 项 目 开发 应 用 的 知识 训 进 行 详细 讲解 ， 在 酚 近 当前 项 目 开发 过 程 的 于 而 
0 


图 3.5 通过 POST 方法 提交 表单 元 素 


图 关键 技术 


本 实例 主要 是 通过 定义 form 表单 的 method 属性 实现 ， 方 法 如 下 : 
<form action=" method="post"> 
看 设计 过 程 
(1) 编写 脚本 文件 index.php。 利 用 <table> 标 签 建 立 网 页 框架 ， 引 入 CSS 文件 。 


(2) 编写 表单 ， 将 提交 方法 定义 为 post， 代 码 如 下 : 
<form action="" method="post"> /提交 方法 为 post 
<br> 
Ea <input class="one" type="text" name="te" size="20" /> 


i Rnbsp: 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" valuc="&nbsp:&nbsp:" /> 
<input class="three" type="reset" name="res" valuc="&nbspi&nbsp:" /> 

</form> 


国 秘笈 心 法 


心 法 领悟 151: 为 什么 POST 方法 是 程序 员 处 理 表单 程序 的 首选 。 
POST 方法 与 GET 方法 不 同 ， 虽 然 都 是 采用 地 址 栏 传递 参数 的 方式 ， 但 是 通过 POST 方式 传递 的 参数 在 地 
址 栏 中 是 不 可 见 的 ， 这 样 就 大 大 降低 了 网 站 或 者 程序 的 外 来 因素 的 威胁 。 


高 级 | 
Ne be 


实例 152 


四 实例 说 明 


实例 151 介绍 了 如 何 通过 POST 方法 提交 表单 元 素 , 本 实例 讲解 如 何 通过 $_POST 方法 获取 表单 元 素 。 运行 
本 实例 ， 效 果 如 图 3.6 所 示 。 


里 
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三 全 


从 软件 工程 的 角度 ， 近 第 项 目的 开发 里 序 ， 系 统 、 全 面 她 介绍 项 目的 开发 六 
对 项 目 开 发 应 用 的 知识 点 进行 详细 讲解 ， 在 家 所 当前 项 目 开发 过 程 的 基础 上 
的 拓展 电 梭 ， 进 行 独立 开发 ! 


图 3.6 通过 $ POST 方法 获取 表单 元 素 


图 关键 技术 


本 实例 主要 是 利用 预定 义 变量 $_POST， 该 变量 是 一 个 自动 全 局 变量 ， 即 它 在 所 有 的 PHP 脚本 中 都 有 效 。 
本 实 袍 通过 尝 击 按钮 实现 访 问 文本 框 信息 的 代码 如 下 : 


a 100px" align="center"><?php echo $_POST[te]:2></td> 
es align="center"><?php echo $_POST[pwd]:?></td> 


图 设计 过 程 
(1) 编写 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表 单 ， 代 码 如 下 : 


<form action="" method="post"> 
<br> 


用 户 名 : <input class="one" type="text" name="te" size="20" /> 
<b> 
密 &nbsp;&nbsp; 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp; " /> 
<input class="three" type="reset" name="res" value="&rnbsp:" /> 

</form> 

(2) 当 单 击 “ 确 定 ” 按 钮 时 ， 程 序 首先 判断 文本 框 和 密码 框 信息 是 否 为 空 ， 如 不 为 空 ， 输 出 通过 $_ POST 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
<php 


ifS_POST[sub]){ / 境 击 按钮 


if($_POST[te] 一 "1 $_POST[pwd] — ""): / 济 断 文本 框 和 密码 框 是 否 为 空 
站 全 二 全 
Jelse{ 
‘<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"> 
<tr> 
<td align="center"> 用 户 名 </td> 
<td align="center"> 密 码 </td> 
<t> 
<tr> 
<td width="100px" align="center"><?php echo $_POST[te]:?></td> 
<td width="100px" align="center"><?php echo $_ POST[pwd]:?></td> 
<ltr> 
</table> 
<?php 
} 
} 
?> 
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心 法 领悟 152: 超级 全 局 变量 $_ POST。 
虽然 $S POST 是 一 个 全 局 变量 ， 但 是 在 访问 的 时 候 不 需要 使 用 关键 字 global。 
高 级 
趣味 指数 : 但 伍 


力 实例 说 明 


GET 方法 是 提交 表单 元 素 的 另 一 种 方法 ， 这 种 方法 虽然 不 是 程序 员 提 交 表 单 的 首选 ， 但 是 在 日 常 的 程序 开 
发 过 程 中 也 是 很 实用 的 。 运 行 本 实例 ， 效 果 如 图 3.7 所 示 。 


习 专业 缩短 苞 能 


标准 厦 以 上 版 本 浊 供 实时 开 级 。 轻 松 襄 受 阴 | 
料 技 开 发 团队 的 开发 成 里 和 经 灶 ， 关 
ECDCLESTT 


图 3.7 通过 GET 方法 提交 表单 元 素 


力 关键 技术 
本 实例 主要 是 通过 定义 form 表单 的 method 属性 来 实现 ， 定 义 方法 如 下 : 


<form action="" method="get"> 
力 设计 过 程 
(1) 编写 脚本 文件 index.php， 利 用 <table> 标 签 建 立 网 页 框架 ， 引 入 CSS 文件 。 
(2) 编写 表单 ， 将 提交 方法 定义 为 get， 全 证 和 
<form action="" method="get"> /提交 方法 为 get 
有 名 <input class="one" type="text" name="te" size="20" /> 


a <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&enbsp: 党 
<input class="three" type="reset" name="res" value="&nbsp: " 

</form> 


国 秘笈 心 ; 
心 法 领悟 153: GET 方法 与 POST 方法 的 本 质 区 别 。 


当 用 户 提交 表单 时 ， 观 察 GET 方法 和 POST 方法 在 地 址 栏 的 区 别 ，POST 方法 不 会 有 任何 变化 , 而 GET 方 
法 将 在 地 址 栏 内 显示 如 图 3.8 所 示 的 内 容 。 


联 Mtp /ocahost/WR/03/0058006/in php?tecarepdarsoftasabz 


本 


图 3.8 GET 方法 提交 地 址 栏 变化 
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虽然 传递 内 容 经 过 一 些 加 密 处 理 ， 但 也 近乎 是 明文 地 将 内 容 显示 出 来 ， 是 非常 不 安全 的 行为 。 


力 实例 说 明 
通过 上 面 实例 的 学 习 ， 相 信用 户 已 经 掌握 了 什么 是 GET 方法 以 及 如 何在 表单 中 使 用 GET 方法 ， 下 面 将 通 
过 $_GET 方法 向 用 户 演示 如 何 获取 表单 元 素 ， 如 图 3.9 所 示 。 
弛 类 学 汀 专业 编程 技能 
于 准 版 以 上 陋 本 灵 殿 实时 天 级 ， 既 松 讲 县 其 | 


科技 弄 尖 团 随 的 开发 成 果 积 色 圣 ， 并 
可 理 型 因 全 开 兴 志 它 折 全 班 
本 


图 3.9 通过 $_ GET 方法 获取 表单 元 素 


图 关键 技术 


本 实例 主要 应 用 预定 义 变量 $_GET 实现 ， 本 变量 是 一 个 自动 全 局 变量 ， 即 它 在 所 有 的 PHP 脚本 中 都 有 效 。 
本 实例 通过 单 击 “确定 ”按钮 ， 应 用 $_GET 方法 获取 文本 框 提交 的 数据 ， 其 代码 如 下 : 


i align="center"><?php echo s GET[te]:?></td> 
<td width="100px" align="center"><?php echo $_GET[pwd]:?></t 
<ir> 


图 设计 过 程 
(1) 编写 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表单 ， 代 码 如 下 ; 


<form action="in.php" method="get"> 
Se 户 名 : <input class="one" type="text" name="te" size="20" /> 


Ee &nbsp: 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" valuec="&nbsp:" /> 
<input class="three" type="reset" name="res" value="&nbsp:" /> 

</form> 


(2) 当 单 击 “ 确 定 ”按钮 时 ， 程 序 首先 判断 文本 框 和 密码 框 信息 是 否 为 空 ， 当 不 为 空 时 ， 输 出 通过 $_GET 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
<? 


hp 
ifS_GET[sub]){ // 单 击 按钮 
if($ ent ||$_GET[pwd] 一 "| // 判 断 文本 框 内 容 
echo "<script>alert( 文 本 框 不 1 


a 
Jelse{ 


<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"><tr><td align="center’> 用 户 名 </td><td align="center"> 密 码 <jtd></tr> 
<tr><td width="100px" align="center"><?php echo $_GET[te]:?></td><td width="100px" align="center"><?php echo 
$_GET[pwd]:?></td></tr></table> 

<?php 


} 
} 
?> 


@” 
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国 秘笈 心 法 


心 法 领悟 154: 超级 全 局 变量 $_GET。 
与 全 局 变量 $_POST 一 样 ，$_GET 方法 也 不 需要 使 用 关键 字 global 来 访问 。 通 过 $_GET 方法 还 可 以 获取 到 
超 链接 传递 的 参数 值 。 


3.2 文本 框 组 件 的 应 用 


文本 框 组 件 是 用 来 输入 任何 类 型 的 单行 文本 、 数 字 或 字母 数据 的 文本 域 。 在 进行 程序 设计 过 程 中 ， 经 常 使 
用 文本 框 组 件 来 获取 用 户 输入 的 信息 。 下 面 通过 具体 实例 来 说 明文 本 框 组 件 在 PHP 中 的 应 用 。 


ee ee 


趣味 指数 : 袜 食 食 食 


力 实例 说 明 


在 开发 网 站 的 过 程 中 ， 一 般 涉及 用 户 注册 的 网 站 模块 都 有 一 个 用 户 注册 的 服务 条 款 ， 个 别 的 服务 条 款 以 
整个 网 页 进行 显示 ， 但 是 有 的 网 站 因 服 务 条 款 篇 幅 过 长 ， 不 适合 使 用 这 种 方式 ， 最 好 的 解决 方法 是 以 文本 域 
的 形式 来 显示 ， 既 可 节省 页 面 ， 又 美观 大 方 。 运 行 本 实例 ， 在 文本 域 中 显示 用 户 注册 的 服务 条 款 ， 运 行 效果 
如 图 3.10 所 示 。 


3.10 ”以 文本 域 形式 显示 数据 


力 关键 技术 
本 实例 主要 应 用 表单 中 的 文本 域 显示 信息 ， 主 要 就 是 设置 文本 域 的 初始 值 ， 代 码 如 下 : 


<textarea name="test" cols="45" rows="8" id- test'><?php echo $myrowltext]:?></textarea> 
参数 说 明 : 

name: 文本 域 的 名 称 。 

cols: 文本 域 的 字符 宽度 。 

rows: 文本 域 显示 的 行 数 。 


力 设计 过 程 
编写 脚本 文件 ， 编 写 文本 域 代码 ， 并 通过 PHP 变量 传递 初始 值 ， 代 码 如 下 


<pip 
$str "用 户 不 得 发 布 违反 国家 行政 法 规 的 内 容 。 /定义 变量 
不 得 发 布 违反 社会 道德 的 内 容 。"; 


> 
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<textarea name="txt" id="one" cols="30" rows="6"><?php echo $str:?></textarea> /传递 初始 值 
<b> 
<br> 
<input type="submit" name="agreen" id="agreen" value=" 接 受 (8)"” disabled="disabled"/> 
Rnbspi&nbsp:&nbsp:&nbsp: 
<input type="submit" name="disagreen" id="disagreen" value=" 不 接 受 " /> 
</div> 
</form> 


图 秘笈 心 法 


心 法 领悟 155: 文本 域 标签 的 初始 值 。 
文本 框 标签 和 其 他 一 些 标签 设置 初始 值 的 方法 是 将 初始 内 容 写 在 value 属性 中 , 而 文本 域 标签 的 初始 值 内 容 
是 写 在 文本 域 的 开始 和 结束 标签 之 间 。 


a 


起 味 指数 :页 廊 宙 宙 


实例 156 


力 实例 说 明 


在 网 站 的 论坛 或 意见 箱 中 ， 留 言 的 内 容 通常 都 是 在 文本 域 中 输入 的 ， 而 文本 域 不 具有 限制 用 户 输入 最 多 字 
符 数 的 功能 ， 因 此 必须 由 开发 人 员 编写 代码 进行 控制 。 运 行 本 实例 ， 在 “意见 内 容 ” 文 本 框 中 只 能 输入 1000 个 
字 节 ， 即 1000 个 英文 字母 或 500 个 中 文 汉字 ， 用 户 在 文本 框 中 每 输入 一 个 字符 ， 下 面 的 字 节 位 置 都 将 自动 计算 
已 输入 字 节 数 和 剩余 字 节 数 ， 运 行 结果 如 图 3.11 所 示 。 


图 3.11 限制 文本 域 输入 的 字符 个 数 


图 关键 技术 


要 实现 限制 多 行文 本 域 输入 的 字符 个 数 ， 关 键 是 应 用 onKeyDown 事件 和 onKeyUp 事件 ， 调 用 自 定义 的 
JavaScript 函数 StatByte0 来 限制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 。 
图 设计 过 程 
(1) 创建 一 个 企业 内 部 意见 箱 的 文本 框 ， 代 码 如 下 : 
<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions"></textarea> 
(2) 添加 显示 字 节 数 的 文本 框 ， 包 括 最 大 字 节 数 、 已 用 字 节 和 剩余 字 节 ， 注 意 此 时 应 该 将 这 3 个 文本 框 设 
置 为 停 用 状态 ， 不 允许 用 户 修改 ， 代 码 如 下 : 
最 大 字 节 数 : 
<input name="maxs" type="text" disabled class="noborder" id="maxs"” value="1000" size="4"> 
ee ns type="text" disabled class="noborder" id="used"” value="0" size="4"> 
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剩余 字 节 : 
<input name="remain" type="text" disabled class="noborder" id="remain" value="1000" size="4"> 


(3) 编写 自 定义 的 JavaScript 函数 StatByte0 用 于 判断 用 户 输入 的 字符 数 是 否 大 于 允许 输入 的 字符 数 ， 并 计 
算 已 用 字 节 数 与 剩余 字 节 数 ， 代 码 如 下 
<SCRIPT language=JavaScript> 
var LastCount =0; 
function StatByte(Message,maxs,Used.Remain){ / 字 节 统计 
var ByteCount = 0; 
var StrValue = Message.value; 
var StrLength = Message.value length; 
Var maxsValue =maxs.value; 
if(LastCount != StrLength) { // 在 此 判断 ， 减 少 循环 次 数 
for (i=0;i<StrLength:i++){ 
ByteCount = (StrValue.charCodeAt(i)<=256)? ByteCount+ 1 :ByteCount+ 2: 
if(ByteCount>maxsValue) { 
Message.value = StrValue.substring(0.2); 
alert(" 留 言 内 容 最 多 不 能 超过 " +maxsValue+ " 个 字 节 ! \n 注意 ， 一 个 汉字 为 两 字 节 。"); 
ByteCount = maxsValue; 
break: 


} 


Used.value = ByteCount; 
Remain.value = maxsValue - ByteCount: 
LastCount = StrLength; 

} 

} 

</SCRIPT> 


(4) 修改 “意见 内 容 ” 文 本 域 的 代码 ， 在 onKeyDown 事件 和 onKeyUp 事件 中 调用 自 定义 的 JavaScript 函 
数 StatByte0)， 限 制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 ， 代 码 如 下 : 


<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions" 
onKeyDown="StatByte(this.form.suggestions.this.form.maxs.this.form.used.this.form.remain):" 
onKeyUp="StatByte(this.form.suggestions.this form. maxs.this.form.used.this.form.remain);"> 
</textarea> 


国 秘笈 心 法 
心 法 领悟 156: 字 节 数 的 计算 。 
在 计算 字 节 数 时 ， 需 要 判断 输入 的 字符 是 汉字 还 是 英文 字母 或 数字 ， 因 为 一 个 汉字 占 两 个 字 节 。 


力 实例 说 明 


在 网 页 中 ， 有 些 文本 框 中 的 信息 是 不 允许 浏览 者 进行 修改 的 ， 即 用 户 只 有 浏览 的 权限 而 没有 修改 的 权限 。 
此 功能 可 以 通过 设置 文本 框 的 只 读 属 性 来 实现 。 运 行 本 实例 ， 在 页 面 中 修改 库存 数量 时 ， 将 弹出 “此 文本 框 为 
只 读 属 性 ， 库 存 数量 不 能 修改 ! ! ”的 提示 框 ， 运 行 结果 如 图 3.12 所 示 。 


国 关键 技术 


本 实例 的 关键 是 文本 框 中 readonly 属性 的 运用 , 通过 它 可 设置 文本 框 的 只 读 属性 , 然后 通过 onfocus 事件 调 
用 JavaScript 脚本 ， 当 用 户 单 击 已 经 设置 为 只 读 属性 的 文本 框 时 ， 弹 出 一 个 提示 对 话 框 。 
使 用 readonly 属性 实现 只 读 的 代码 如 下 : 


<input id="0" class="0" type="text" readonly value="0100521041'/> 


” i ed i 


趣味 指数 : 妇女 太太 


188 


第 3 章 Web 页 面 交互 


[0100521041 
牛奶 


国 [oo 
加 


图 3.12 设置 文本 框 的 只 读 属 性 
力 设计 过 程 
新 建 index.php 文件 。 编 写 表格 ， 在 表格 中 插入 <fom> 标 签 ， 编 写 文本 框 ， 设 置 文本 框 的 属性 为 readonly， 


商品 编号 ;<input id="o" class="o" type="text" readonly valuc=0100521041/><br> 

商品 名 称 ，<input id="o"type="text" value=" 酸 牛奶 " onfocus="this.value="" /><br> 

库存 数量 ，<input id="o" class="n"type="text" disabled="disabled" value="100 件 " /><br> 
管理 员工 : <input id="o"type="text" value="001" /> 

</form> 


图 秘笈 心 法 


心 法 领悟 157: 使 用 readonly 的 小 技巧 。 
在 使 用 readonly 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


高 级 
起 味 指教: 宙 宙 机 


实例 158 


力 实例 说 明 


在 物流 管理 系统 中 ， 经 常 需要 计算 出 库 商品 的 金额 或 入 库 商 品 的 金额 ， 若 以 手工 计算 ， 比 较 麻烦 而 且 容易 
出 错 ， 如 果 在 程序 中 实现 自动 计算 金额 功能 ， 则 可 以 减少 许多 不 必要 的 麻烦 。 运行 本 实例 ,效果 如 图 3.13 所 示 。 


商品 六 5 
商品 单价 :| 


库存 数量 : [35 


人 人 金额 总 计 : 350 


3.13 ”自动 计算 金额 
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国 关键 技术 


本 实例 主要 通过 触发 表单 控件 的 blur 事件 ， 即 表单 控件 失去 焦点 时 ， 实 现 自动 计算 金额 。 实 现 此 功能 的 
JavaScript 代码 如 下 : 
$(".0").blur(functionO{ // 当 商品 单价 文本 框 失去 焦点 
var price = $(".0").valO: 
var num = $(".n").val|; 
var amount = price * num; 
、 S$(".e").val(amount):; 
图 设计 过 程 
编写 脚本 文件 并 命名 为 index.php。 引 入 CSS 样式 表 文 件 ， 导 入 JavaScript 脚本 。 编 写 表单 ， 当 商品 单价 失 
去 焦点 时 自动 计算 金额 ， 核 心 代码 如 下 : 


<form action=" method="post" name="form1"> 

商品 编号 ，<input id="o" type="text" readonly valuc= 酸牛奶 /><br> 
商品 单价 ;<input id="o" type="text"class="o" value="0.0"/><br> 

库存 数量 : <input id="o" class="n"type="text" value="35" readonly /><br> 
金额 总 计 : <input id="o" class="e"type="text" value="0.0" /> 

</form> 


秘笈 心 
心 法 领悟 158: 关于 blur 事件 。 


用 于 当 blur 事件 ( 即 失去 焦点 事件 ) 发 生 时 执行 JavaScript 代码 。 适 用 对 象 包括 Button、Checkbox、FileUpload、 
Layer、 Password、 Radio、Reset、Select、Submit、Text、Textarea 和 Window。 


BE 


图 实例 说 明 


在 实例 157 中 已 经 介绍 了 文本 框 只 读 属 性 的 相关 知识 ， 下 面 介 绍 一 种 与 只 读 属 性 类 似 的 属性 ， 即 设置 文本 
框 默认 值 。 运 行 本 实例 ， 效 果 如 图 3.14 所 示 ， 设 置 文本 框 的 默认 颜色 为 灰色 ， 当 在 用 户 名 中 输入 信息 时 动态 改 
变 文本 框 默 认 值 信息 。 


高 级 
趣味 指数 : 座机 廊 贾 


图 3.14 为 文本 框 设置 默认 值 


力 关键 技术 
本 实例 的 关键 是 通过 disabled 属性 设置 文本 框 的 默认 值 ， 然 后 通过 相关 事件 ,动态 改变 默认 值 文本 框 的 值 。 
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使 用 disabled 属性 设置 默认 值 的 代码 如 下 : 


<input id="0" class="0" type="text" disabled value="0100521041’/> 
图 设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 样式 表 文 件 ， 编 写 表单 ， 代 码 如 下 : 


table width="350" border="0" class="p"> 
<u> 
<td width="100"> 用 户 名 : <ltd> 
<td align="left"><input class="m id="name"type="text" /></td> 
<ltr> 
<t> 
<td> 职 &nbsp:&nbsp: 位 : <ltd> 
<td align="left"><input class="m"type="text" id="type" disabled valuc= "自动 选取 "></td> 
<ltr> 
</table> 


(2) 定义 i 脚本 方法 ， 动 态 改变 文本 框 的 默认 值 ， 代 码 如 下 : 
S$("#name") keyup(function() 
Var name = $(" 2 0 
var manager = 
if(name — mt 
S$S("#type").val(" 经 理 "); 
Jelse{ 
S("#type").val(" 程 序 员 "); 


D; 
力 秘笈 心 法 
心 法 领悟 159: 关于 设置 文本 框 的 默认 值 。 


(1) 设置 文本 框 的 默认 值 与 设置 文本 框 的 只 读 属性 在 效果 上 是 相同 的 。 
(2) 在 使 用 disabled 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


实例 160 趣味 指数 : 依依 依依 


力 实例 说 明 


form 表单 的 文本 框 在 默认 情况 下 不 够 美观 ， 使 用 默认 的 文本 框 样式 将 影响 网 站 的 视觉 效果 。 运 行 本 实例 ， 
效果 如 图 3.15 所 示 ， 利 用 CSS 代码 和 简单 的 JavaScript 代码 ， 使 文本 框 变 得 生动 、 有 特色 。 


图 3.15 设置 文本 框 样式 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


本 实例 首先 为 文本 框 定义 CSS 样式 ， 然 后 通过 设置 鼠标 事件 调用 CSS 样式 ， 动 态 改变 文本 框 的 边框 颜色 。 
使 用 CSS 样式 的 代码 如 下 : 


mouse{ 
border:1px #EF0000 solid: 
background-color#FFCCFF: 


} 
使 用 JavaScript 定义 鼠标 事件 ， 代 码 如 下 : 
S$("#n").mouseover(function|O{ 
S$("#n").css( {border:"1px #0099FF solid",background:"white"}); 
S$("#n") -mouscout(fimctionO{ 
S("#n").css( {border:"1px red solid".background:"#FFCCFF"}): 
和 
DD; 
S$("#na") .mouseover(functionO{ 
S("#na").css({border:"1px #0099FF solid".background:"white"}): 
S$("#na").mouseout(function(): 
S("#na").css({border:"1px red solid".background:"#FFCCFF"}); 
D; 
和 


国 设计 过 程 
(1) 新 建 index php 文件 ， 建 立 网 页 架构 ， 编 写 form 表单 ， 其 关键 代码 如 下 : 


<table width="350" border="0" class="p"> 
<tr> 
<td width="100"> 用 户 名 :</td> 
<td align="left"><input type="text" class="mouse" id="n"/></td> 
<it> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <ltd> 
<td align="left"><input type="text" class="mouse" id="na" /></td> 


es 
(2) 引入 CSS 样式 和 JavaScript 脚本 ， 核 心 代码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 160: 引入 CSS 样式 。 
定义 CSS 样式 表 后 需要 引入 到 相关 脚本 文件 中 才能 起 到 作用 。 一 般 是 在 <meta> 标 签 下 ， 利 用 <link> 标 签 引 
入 。 以 本 实例 为 例 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/ine.css"/> 


图 实例 说 明 


文本 域 本 身 有 自 带 的 滚动 条 ， 用 户 可 以 通过 滚动 条 浏览 文本 域 中 的 所 有 内 容 ， 但 是 在 初始 情况 下 ， 用 户 
可 以 根据 需要 设置 文本 域 的 列 宽 ， 也 就 是 确定 文本 域 在 初始 情况 下 显示 多 少 内 容 。 运行 本 实例 ,效果 如 图 3.16 
所 示 。 


高 级 | 
趣味 指数 : 请 请 博朗 ， 
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图 3.16 文本 域 的 滚动 条 


图 关键 技术 
ps i JavaScript 代码 ， 动 态 改变 文本 框 的 rows 属性 。JavaScript 代码 如 下 : 


S$("#down").click(function()- 
S$("textarea").attr(" 本 "8"); 
S$("#up").click(functionO{ 
S("textarea").attr("rows","1"); 
D); 
看 设计 过 程 
(1) 新 建 index.php 文件 , 通过 <table> 标 签 建立 网 页 框架 , 输入 文本 域 代码 ， 引 入 CSS 样式 表 和 JavaScript 
脚本 ， 代 码 如 下 : 


<table width="600" height="600" border="0" align="center" background="pic/bgjpg"> 
<t> 
<td align="center"> 
<textarea cols="40"><?php echo $str:?></textarea><br><br> 
<input type="button" id='down' value='&nbsp; /> 
<input type="button" id='up' value='&nbsp: '/> 


(2) 编写 JavaScript 脚本 文件 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 


心 法 领悟 161: 编写 JavaScript 代码 的 注意 事项 。 
编写 JavaScript 代码 时 ， 要 注意 JavaScript 代码 是 区 分 函数 大 小 写 的 。 


3.3 ”下拉 列表 的 应 用 


下 拉 列 表 是 一 种 最 节省 空间 的 数据 显示 方式 ， 正 常 状态 下 只 能 看 到 一 个 选项 ， 单 击 控制 按钮 后 ， 可 以 显示 
一 定数 量 的 选项 ， 如 果 超 出 这 个 数量 ， 会 自动 显示 滚动 条 ， 浏 览 者 可 以 通过 拖 动 滚动 条 来 查看 各 选项 。 


实 级 | 


力 实例 说 明 
在 进行 网 站 开发 的 过 程 中 ， 经 常会 用 到 相互 关联 的 菜单 。 例 如 ， 省 、 市 、 县 3 级 联动 或 者 省 、 市 2 级 联动 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
菜单 。 在 本 实例 中 将 讲解 如 何 实现 省 、 市 2 级 联动 菜单 ， 其 运行 效果 如 图 3.17 所 示 。 


图 3.17 省 、 市 级 联动 菜单 


力 关键 技术 


本 实例 通过 设置 change 事件 实现 联动 的 下 拉 列 表 ， 并 且 根 据 1 级 下 拉 列 表 传 递 的 不 同 参数 ， 显 示 不 同 的 2 
级 下 拉 列 表 信 息 。 实 现 这 些 功 能 的 JavaScript 代码 如 下 : 
S("#select1").change( function0 { 
var id = $("#select1").valO; 
iflid=— D{ 
S$.get(index.php’, null, fanction(data){ 

S$("span").emptyO; 
S$("span").append("<select><option> 长 春 </opton><option> 松 原 </opton><option> 通 辽 </opton></select>"); 


D; 
Jelse{ 
S$.get(index.php' null, function(data){ 
S("span").emptyO); 
$("span").append("<select><option> 大 连 </opton><option> 旅 顺 </opton><option> 钱 鱼 圈 </opton></select>"); 
D; 
} 
D; 


图 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 表 和 JavaScript 脚本 。 编 写 1 级 下 拉 列 表 ， 设置 <option> 标 签 属性 value 
的 值 ， 代 码 如 下 : 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 

</select> 


(2) 编写 JavaScript 代码 ， 当 选择 1 级 下 拉 列 表 项 时 ， 触 发 change 事件 ， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 162: JavaScript 脚本 语言 的 小 技巧 。 
如 果 在 JavaScript 脚本 中 出 现 长 语句 , 可 以 在 JavaScript 语句 的 最 后 加 上 字符 “\”, 使 一 条 长 语句 分 多 行 编写 。 


单 级 | 
图 实例 说 明 


实例 162 中 讲解 了 如 何 实现 2 级 联动 菜单 ， 下 面 将 讲解 如 何 实现 省 、 市 、 县 3 级 联动 菜单 。 运 行 本 实例 ， 
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效果 如 图 3.18 所 示 。 


图 3.18 省 、 市 、 县 级 联动 菜单 


力 关键 技术 


实现 省 、 市 、 县 3 级 联动 菜单 与 实现 省 、 市 2 级 联动 菜单 的 思路 大 致 相同 ， 但 是 需要 套用 多 层 的 if...else.… 
语句 实现 。 


力 设计 过 程 
(1) 创建 脚本 文件 ， 命 名 为 index.php。 创 建 form 表单 ， 编 写 下 拉 列 表 框 ， 定 义 2 级 联动 和 3 级 联动 的 下 
拉 列 表 选 项 ， 代 码 如 下 : 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 
</select> 
<span id='two'></span> 
<span id='three'></span> 
(2) 编写 JavaScript 脚本 文件 ， 当 触发 change 事件 时 ， 实 现 联动 效果 ， 代 码 如 下 : 
$("#select1").change( function() { 
var id = $("#select1").val|); 
iflid— D{ 
S$.get('index.php', null, function(data){ 
S$("#two").emptyO: 
$("#two").append("<select id='select2'><option> 请 选择 </opton><option value='1> 长 春 </opton><option value=2> 松 原 
</opton></select>"); 
S$("#select2").change( function0 { 
var page = $("#select2").valO; 
iflpage — D{ 
S$("#three").empty(): 
$("#three").append("<select><option> 双 阳 </opton><option> 农 安 </opton></select>"); 
jelse{ 
ifl(page — 2){ 
S("#three").emptyO: 
S$("#three").append("<select><option> 乾 安 </opton><option> 大 安 </opton></select>"); 


» 
D); 
D; 
jslse{ 

S$.get(index.php', null, function(data){ 
S$("#two").emptyO: 
S$("#two").append("<select id='select3'><option value="1> 大 连 </opton><option value='2 人 > 旅顺 </opton></select>"); 
S$("#select3").change( function() { 

var page = $("#select3").val|): 
ifl(page — D{ 
S$("#three").emptyO: 
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S$("#three").append("<select><option> 西 岗 </opton><option> 沙 河口 </opton></select>"): 


国 秘笈 心 ; 
心 法 领悟 163: 打造 优秀 的 3 级 联动 菜单 。 


本 实例 旨 在 讲述 实现 3 级 联动 菜单 的 原理 ， 在 实际 开发 中 是 不 建议 使 用 让 .else.…. 语 句 的 ， 因 为 这 样 的 多 层 
顽 套 方式 一 方面 使 程序 本 身 的 可 读 性 变 差 ， 而 且 还 有 可 能 不 利于 程序 员 编程 。 


要 联机 的 网 站 高 级 | 


趣味 指数 : 址 食 食 侠 | 


实例 164 


力 实例 说 明 


在 开发 网 站 程序 的 过 程 中 ， 多 数 网 站 都 设置 了 友情 链接 这 一 模块 ， 通 常情 况 下 ， 链 接 的 网 站 以 图 标 、 网 站 
名 或 地 址 的 形式 显示 在 页 面 中 ， 浏 览 者 可 通过 单 击 超 链 接 进入 所 要 访问 的 网 站 。 为 了 更 好 地 利用 页 面 ， 可 以 通 
过 下 拉 列 表 框 的 方法 来 创建 友情 链接 。 运 行 本 实例 ， 当 用 户 选 择 下 拉 列 表 框 中 所 要 联机 的 网 站 后 〈 如 图 3.19 所 
示 ) ， 单 击 GO 按钮 可 以 立即 链接 到 指定 的 网 站 。 


图 3.19 应 用 下 拉 列 表 框 选择 要 联机 的 网 站 


力 关键 技术 


本 实例 首先 将 文本 框 的 value 属性 值 定义 为 所 要 连接 的 人 P 地 址 ， 然 后 通过 设置 鼠标 的 单 击 事件 实现 链接 到 


指定 的 网 站 。JavaScript 代码 如 下 : 

S$(document) .ready(function(){ 
S$("#button").click(functionO{ 

var sel = $("#sel").valO: 

iflsel (=){ 

get(sel): 
Jelse{ 
alert( 请 选择 连接 内 容 '); 
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力 设计 过 程 
(1) 新 建 index php 文件 ， 创 建 下 拉 列表 框 ， 并 添加 下 拉 列 表 框 选项 值 ， 代 码 如 下 


<selectid-'sel> 

<option value="" > 友情 链接 </option> 
<option value="http://www.126.com">126 邮箱 </option> 
<option value="http://www.163.com">163 邮箱 </option> 
<option value="http://Wwww.4399.com">4399 小 游戏 </option> 

‘</select> 

<input id="button" class=button' type="submit" valuc="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" 户 

(2) 编写 JavaScript 脚本 文件 ， 当 单 击 GO 按钮 时 触发 事件 ， 完 成 页 面 的 跳 转 操作 。 


国 秘笈 心 法 


心 法 领悟 164: 使 用 CSS 样式 表 的 好 处 。 
利用 CSS 样式 可 以 大 量 减 少 网 页 代码 ， 其 原理 就 是 在 网 页 中 自 定义 样式 表 的 选择 符 ， 在 网 页 中 大 量 引 用 这 
些 选择 符 即 可 。 


趣味 指数 : 伍 食 三 食 


图 实例 说 明 


通常 ， 网 页 中 应 用 的 下 拉 列 表 框 的 选项 值 是 固定 不 变 的 ， 这 样 就 存在 一 些 弊病 ， 如 不 能 向 下 拉 列 表 框 中 添 
加 新 的 选项 值 ,如 果 能 编写 可 以 输入 字符 的 下 拉 列 表 框 , 就 方便 很 多 。 运 行 本 实例 , 在 部 门 的 下 拉 列 表 框 中 有 “ 生 
产 部 ”、“ 业 务 部 ”和 “技术 部 ”3 个 选项 ， 如 果 要 添加 一 个 “文化 部 ”， 直 接 在 下 拉 列 表 框 中 输入 “文化 部 ” 
即 可 ， 运 行 结 果 如 图 3.20 所 示 


很 方便 ! 


3.20 可 输入 字符 的 下 拉 菜 单 


力 关键 技术 


本 实例 的 开发 思路 如 下 : 网 页 中 下 拉 列 表 的 选项 值 是 固定 的 ， 要 实现 在 下 拉 列 表 框 中 输入 文字 ， 首 先 要 捕 
获 用 户 的 键盘 事件 ， 然 后 根据 键盘 输入 的 数据 动态 添加 下 拉 列 表 框 的 选项 ， 同 时 还 要 判断 用 户 按 下 的 是 
Backspace 键 还 是 Space 键 ， 如 果 是 Backspace 键 ， 则 需要 从 光标 指针 位 置 向 前 删除 一 个 字符 ， 如 果 是 Space 键 ， 
则 需要 在 光标 指针 位 置 添加 一 个 空格 字符 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
另外 ， 本 实例 还 利用 onKeyPress 和 onKeyUp 事件 调用 JavaScript 自 定义 函数 press(opb 和 up(opb。 


图 设计 过 程 


(1) 在 页 面 中 创建 部 门下 拉 列 表 框 ， 其 中 包括 “生产 部 ”、“ 业 务 部 ”和 “技术 部 ”3 个 选项 ， 代 码 如 下 : 
<form name="form1" method="post" action="index php" onKeyPress="press(3)" onKeyUp="up(3)"> 
<select name="userclass" size="1" id="userclass"> 
<option value=" 生 产 部 " selected> 生 产 部 </option> 
<option value=" 业 务 部 "> 业务 部 </option> 
<option value=" 技 术 部 "> 技术 部 </option> 
</select> 
</form> 


(2) 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 press(opt)， 用 于 在 下 拉 列 表 框 中 添加 新 的 选项 ， 并 
将 用 户 输 入 的 信息 添加 到 下 拉 列 表 框 中 ， 设 置 该 选项 为 选中 项 。 
然后 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 up(opt), 当 用 户 按 Backspace 键 时 , 将 已 经 写 到 下 拉 


列表 框 中 的 文字 逐个 删除 ， 当 用 户 按 Space 键 时 ， 在 下 拉 列 表 框 中 添加 一 个 空格 字符 ， 代 码 如 下 : 
function press(opt{ 
/lopt 表示 现 有 可 选项 的 数目 
forml.userclass.options[opt]j=new Option(ok=(forml.userclass.options[opt])? 
forml .userclass.options[opt] innerText+String fromCharCode(event.keyCode): 
String fromCharCode(event.keyCode).ok) 
forml.userclass.selectedIndex=opt; 
} 
function up(op){ 
/lopt 表示 现 有 可 选项 的 数目 
ifforml .userclass.options[opt]){ 
iflevent keyCode—8){ 
var str=forml.userclass.options[opt].innerText: 
var len=str.length; 
forml.userclass.options[opt] innerText=str.substring(0,len-1); 
if(forml .userclass.options[opt] innerText—" ")userclass.remove(2); 
} 
这 eventkeyCode 一 32){ 
forml.userclass.options[opt] innerTextt=" "; 
1 
} 
} 
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心 法 领悟 165: 使 用 JavaScript 代码 删除 输入 文字 的 注意 事项 。 
在 删除 输入 选项 中 的 文字 时 ， 如 果 删 除 到 最 后 一 个 字符 ， 则 将 该 选项 一 同 删除 ， 同 时 改变 下 拉 列 表 框 的 
选中 项 。 


实例 166 


趣味 指数 : 帘 丰 本 容 | 


力 实例 说 明 


在 注册 登录 模块 中 ,下拉 列 表 框 往往 被 应 用 在 选择 用 户 性 别 上 ， 如果 用 户 忘记 选择 此 下 拉 列 表 框 中 的 内 容 ， 
就 很 容易 把 注册 信息 弄 错 。 解 决 这 个 问题 的 方法 是 为 下 拉 列 表 框 设 置 默 认 值 ， 如 图 3.21 所 示 ， 当 没有 对 下 拉 列 
表 框 进行 操作 时 ， 将 弹出 提示 信息 。 
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图 3.21 设置 下 拉 列 表 框 的 默认 值 


图 关键 技术 


本 实例 首先 为 下 拉 列表 框 设置 默认 值 ， 然 后 通过 设置 按钮 的 单 击 事件 实现 当 用 户 单 击 “提交 ”按钮 时 ， 判 
断 下 拉 列 表 框 的 内 容 是 否 被 选择 。 


使 用 selected 属性 实现 设置 默认 值 的 代码 如 下 : 
<option sclected value="1"> 请 选择 性 别 </option> 


图 设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 文件 和 JavaScript 脚本 ， 编 写 下 拉 列 表 框 ， 代 码 如 下 : 


sclect> 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
/select> 
<input id="one" type="button" value="&enbsp:é&enbsp;&nbsp: Gnbsp; &nbsp:&enbsp:éenbsp:&enbsp:" /> 
(2) 编写 JavaScript 代码 ， 当 按钮 被 单 击 时 触发 事件 ， 其 代码 如 下 : 
S$(document) ready(functionO{ 
$("#one").click(functionO{ 
var value = $("select").val(); 
if(value — D{ 
alert(" 您 没有 选择 性 别 "); 


图 秘笈 心 法 
心 法 领悟 166: 关于 设置 下 拉 列 表 框 的 默认 值 。 
在 使 用 selected 时 ， 只 需 在 <option> 标 记 中 加 入 属性 名 称 即 可 ， 其 代码 如 下 : 


‘<option selected="selected"></option> 
a 浊 式 级 | 
力 实例 说 明 


对 页 面 的 美化 处 理 并 不 属于 程序 员 的 工作 范畴 ， 而 是 属于 前 台 美工 的 分 内 之 事 ， 但 是 像 这 种 美化 下 拉 列 表 
框 的 小 事情 ， 程 序 员 如 果 还 要 和 美工 去 协调 未 免 有 点 浪费 时 间 ， 所 以 学 习 一 些 基本 的 页 面 美 化 方法 还 是 很 有 必 
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要 的 。 运 行 本 实例 ， 效 果 如 图 3.22 所 示 。 


图 3.22 设置 下 拉 列 表 框 的 样式 


力 关键 技术 
本 实例 运用 CSS 样式 表 改变 下 拉 列 表 框 的 样式 ， 代 码 如 下 : 


select{ 
width:100px: 
font-family:" 楷 体 _GB2312"; 
font-size:14px; 
color-#FFFFFF; 
background-color:#000000; 
} 


力 设计 过 程 


(1) 创建 index.php 文件 ， 载 入 CSS 样式 ， 编 写 下 拉 列 表 框 ， 代 码 如 下 : 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
</select> 


(2) 定义 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 
国 秘笈 心 法 


心 法 领悟 167: 关于 设置 下 拉 列 表 框 的 样式 。 
支持 下 拉 列 表 框 的 CSS 样式 很 少 ， 所 以 想 设置 更 多 的 样式 相对 来 说 会 很 麻烦 。 如 果 非 要 定义 一 个 漂亮 的 下 
拉 列 表 样式 ， 最 好 利用 JavaScript 代码 自行 编写 。 


实例 168 


国 实例 说 明 


实例 164 中 已 经 讲解 了 如 何 跳 转 到 链接 网 站 的 方法 ， 本 实例 与 实例 164 在 实现 思路 上 是 相同 的 ， 唯 一 不 同 
的 是 在 下 拉 列 表 框 里 通过 打开 新 窗口 实现 跳 转 。 运 行 本 实例 ， 效 果 如 图 3.23 所 示 。 
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施 步 票 。 帮 助 编程 者 提 


图 3.23 选择 链接 网 站 


图 关键 技术 


本 实例 实现 的 方法 是 定义 JavaScript 脚本 的 change 事件 ， 通 过 JavaScript 的 window.open() 方 法 ， 实 现 新 页 


面 的 跳 转 ， 代 码 如 下 : 
S$(document).ready(function(){ 
S("#sel").change(function|{ 

window.open($("#sel").val|); 
D); 
D; 


力 设计 过 程 


(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 表 和 JavaScript 脚本 ， 编 写 下拉 列 表 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/ine.css"/> 
<script type="textjavaseript" sre="../js/jquery-1.3.2.s"></script> 
<script type="textjavaseript" sre="js/in:js"></seript> 
<select id="sel" > 
<option> 友 情 链接 </option> 
<option value='http://www.126.com'>126 邮箱 </option> 
<option value='http://www.163.com'>163 邮箱 </option> 
<option value= http://www.4399.com'>4399 小 游戏 </option> 
</select> 


(2) 编写 JavaScript 脚本 文件 ， 当 发 生 change 事件 时 发 生 跳 转 。 
力 秘笈 心 法 


心 法 领悟 168: 关于 JavaScript。 
本 实例 主要 采用 JavaScript 语言 和 jQuery 框架 编写 , jQuery 框架 是 以 JavaScript 语言 编写 的 , 所 以 两 者 可 以 
混 编 。 


高 级 | 
趣味 指数 : 会 依依 会 


实例 169 


力 实例 说 明 


Tab 键 在 编写 Word 等 文档 时 是 经 常 被 用 到 的 。 在 网 页 的 文本 域 中 ， 按 Tab 键 是 进行 下 一 个 切换 项 的 指示 ， 
如 何在 文本 域 中 体现 Tab 键 呢 ? 本 实例 将 向 用 户 讲解 。 运 行 本 实例 ， 效 果 如 图 3.24 所 示 。 
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高 限 公司 是 国 


i 


图 3.24 文本 域 中 体现 Tab 键 


图 关键 技术 
本 实例 主要 是 通过 JavaScript 代码 定义 onkeydown 事件 实现 的 ， 代 码 如 下 : 


function editTabO{ 
var code, sel, tmp, r 
var tabs="" 
event.returnValue = false 
sel =event.srcElement.document.selection.createcRange() 
r=event.srcElement.createTextRange() 
switch (event. keyCode){ 
case (8): 
if(!(sel.getClientRects(.length > 1)){ 
event.returnValue = true 
retum 
} 
code =sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRect().left, scl.getClientRects|[0].top) 
sel.setEndPoint("startToStart", tmp) 
sel.text = sel.text.replace(/^\t/gm, "") 
code = code.replace(/^\t/gm. "").replace(/\r\n/g, mr 
rfindText(code) 
.select() 
break 
case (9): 
if (sel.getClientRects().length > 1){ 
code = sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRectO .left sel.getClientRectsO[0].top) 
sel.setEndPoint("startToStart", tmp) 
sel.text = "\t"+sel.text.replace(/\r\n/g, wet) 
code = code.replace(/\r\n/g. mt) 
rfindText(code) 
rselectO 
Yelse{ 
sel.text = "\t" 
selselectO 
} 
break 


case (13): 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRect().left. sel.getClientRectsO[0].top) 
tmp.setEndPoint("endToEnd", sel) 
for (var i=0; tmp.text.match(/^[\t]+/g) && i<tmp.text.match(/^[\t]+/g)[0].length: i++) tabs += "\t" 
sel.text = "\r\n"+tabs 
sel.select| 
break 
defanlt: 
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event.retumValue = true 
break 


} 
} 


设计 过 程 
(1) 创建 脚本 文件 ， 引 入 JavaScript 脚本 ， 编 写 文本 域 标签 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/inc.css"/> 
‘<script type="textjavascript" sre="js/in.js"></script> 
<textarea cols="30" name="text" rows="3" onkeydown="editTab()"></textarca> 


(2) 当 按 下 键盘 按键 时 触发 事件 ， 代 码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 169: JavaScript 脚本 的 引用 。 
本 实例 调用 JavaScript 中 的 editTab0 函 数 完 成 对 Tab 键 的 控制 ,在 页 面 中 引用 JavaScript 文件 的 方法 是 应 用 


<script> 标 签 ， 其 代码 如 下 : 
Es 


3.4 表单 元 素 的 动态 操作 


所 谓 动 态 操作 表单 元 素 是 指 页 面 中 的 表单 元 素 并 不 是 固定 不 变 的 ， 而 是 在 程序 执行 时 由 系统 根据 实际 情况 
自动 生成 。 这 里 将 通过 实际 的 例子 来 介绍 如 何 动态 生成 表单 元 素 。 


Eee 
图 实例 说 明 


在 开发 程序 的 过 程 中 ， 经 常 应 用 到 在 线 投票 模块 ， 其 使 用 非常 简单 ， 只 要 选中 一 个 单 选 按钮 或 者 多 个 复 选 
框 所 对 应 的 投票 主题 后 ， 单 击 “ 提 交 ” 按 钮 即 可 完成 投票 。 本 实例 将 介绍 投票 系统 的 操作 原理 ， 当 选中 一 个 投 
票 主题 之 后 ， 就 会 弹出 相应 的 投票 选区 ， 在 该 选区 中 可 以 添加 投票 并 可 以 看 到 投票 的 结果 ， 运 行 结果 如 图 3.25 
所 示 。 


如 果 在 编程 词典 中 没有 您 需要 的 录像 ， 讲 及 时 反 博 给 我 们 ， 我 们 全 力 安排 专 家 其 |" 
ee 


图 3.25 在 线 统计 
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图 关键 技术 
本 实例 主要 是 通过 文件 操作 和 正则 表达 式 函 数 实现 在 线 统计 程序 。 其 中 文件 操作 的 核心 代码 如 下 : 


Sfile = file get contents("info.txt): 
if(sfile —"™"){ 
Sopenn = fopen("info.txt",a); 
fwrite($openn,'a); 
fclose($openn); 
} 


ipreg_match(vSipSflej{ 
echo "<script>alert( 同 一 个 IP 地 址 ， 不 能 投票 两 次 ):</script>"; 


exit; 


Yelse{ 

这 !$open = fopen("info.txt",a') { 
print "文件 不 存在 ， 请 创建 "; 
exit; 

Jelse{ 
fwrite($open,$ip); 
felose($open); 

} 

E 


力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 文件 和 JavaSeript 脚本 ， 编 写 单 选 按钮 ， 代 
码 如 下 : 


<form action="" method="post"> 
<tr> 
<td class="three"><input id="id" name="check" checked type="radio" value="1" /> 上 网 </td> 
<td><img sre="pic/logol.JPG" /><font color='red' size="-1">10 人 </font></td> 
<ltr> 
<tr> 
<td class= "three"><input id="id"name="check" type="radio" value="2" /> 去 娱乐 场所 </td> 
<td><img sre="pic/logo2.JPG" /><font color='red'size="-1">15 人 </font></td> 
<itr> 
<tr> 
<td class="three"><input id="id"name="check" type="radio" value="3" /> 带 着 女友 轿 街 <htd> 
<td><img sre="pic/logo3.JPG" /><font color='red'size="-1">20 人 </font></td> 
<t> 
<tr> 
<td class="three"><input id="id"name="check" type="radio" value="4" /> 睡觉 </td> 
<td><img sre="pic/logo4.JPG" /><font color='red'size="-1">5 人 </font></td> 
<ltr> 
</form> 


(2) 当 单 击 “ 确 定 ”按钮 时 ， 首 先 获 取 客户 端 IP 地 址 ， 然 后 将 数据 写 入 文本 文件 中 ， 最 后 根据 提交 的 值 
通过 switch 语句 进行 判断 并 给 出 提示 信息 ， 代 码 如 下 : 


<?php 
if($ POST[sub){ 
$ip =$_SERVER[REMOTE_ADDR]: // 取 得 客户 端 他 地 址 
Sfile = file_get_contents(info.txt); // 将 文件 内 容 读 取 到 字符 串 
if($file 一 ""){f /如 果 文 件 内 容 为 空 
Sopenn = fopen("info.txt",a); /条 开 info txt 文件 
fwrite($openn,'a’); // 向 文件 中 写 入 一 个 字符 
fclose($openn): /关闭 文件 
} 
if(preg_match("/$ip/",$file){ /匹配 字符 串 
echo "<script>alert(' 同 一 个 IP 地 址 ， 不 能 投票 两 次 ”);</script>"; 
exit /退出 
yelse{ 


if(!Sopen = fopen("info.txt"™,a) { 
print "文件 不 存在 ， 请 创建" 
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exit 
jslsef 
fwrite(Sopen.Sip): 
felose($open);: 
} 
} 
switch($_ POST[check) { /switch 选择 语句 
Case "2": 
echo "<script>alert(' 您 选择 去 娱乐 场所 "):</script>"; 
break 
case "3": 
echo "<scripf>alert( 您 选择 和 女友 逛街 ):</scripf>": 
break 
case "4": 


echo "<script>alert(' 您 选择 睡觉 );</script>"; 
break 


case "1": 
echo "<script>alert( 您 选择 上 网 ');</script>"; 
break; 

} 


} 
笈 心 法 
心 法 领悟 170， 关于 对 文件 的 操作 。 


文件 的 操作 对 于 所 有 学 习 PHP 这 门 语言 的 人 来 说 都 会 感到 头疼 ， 特 别 是 对 文件 高 级 操作 中 的 指针 的 理解 ， 
更 是 如 此 。 所 以 笔者 建议 ， 在 学 习 这 部 分 知识 时 ， 一 定 要 先 打 好 基础 ， 然 后 多 实践 、 多 思考 。 


POO 


高 级 


趣味 指教 : 址 广 三 三 


力 实例 说 明 


论坛 系统 中 的 会 员 有 不 同 的 级 别 ， 一 种 是 超级 会 员 ， 拥 有 对 论坛 的 管理 权限 ， 另 一 种 是 普通 会 员 ， 只 能 发 
布 和 回复 论坛 信息 。 因此 在 论坛 的 权限 设置 模块 中 就 需要 应 用 单 选 按钮 对 超级 会 员 和 普通 会 员 设置 不 同 的 权限 。 
在 本 实例 中 ， 选 中 “超级 用 户 ” 单 选 按钮 时 ， 其 下 方 将 列 出 网 站 的 所 有 管理 模块 ， 管 理 员 可 以 为 超级 会 员 设置 
管理 权限 ， 运 行 结 果 如 图 3.26 所 示 ; 选中 “普通 用 户 ” 单 选 按钮 ， 运 行 结 果 如 图 3.27 所 示 。 


如 果 在 妨 程 局 条 中 没有 您 需要 的 录像 ， 请 及 时 反 情 给 我 们 ， 我 们 全 力 安 撑 专 家 息 / 如 军 友 妨 径 汝 两 中 冯 有 您 需 委 的 好 煞 ， 语 及 时 反馈 俗 我 们 ， 我 们 全 力 安排 专家 担 / 
开发 视频 录像 ， 并 及 时 升级 到 坊 程 词典 录像 中 ， 开发 视频 录像 ， 并 及 时 升 弘 号 编 年 同 此 又 像 十 。 
= 
mn 
NM 


T 
BR 
NS 


图 3.26 超级 用 户 设置 3.27 普通 用 户 设置 
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图 关键 技术 


选中 单 选 按钮 后 显示 其 他 表单 元 素 的 功能 ， 主 要 利用 JavaScript 设置 表格 的 display 样式 来 实现 表格 的 显示 
和 隐藏 。 通 过 设置 表格 的 ID 属性 ， 可 以 实现 对 表格 的 整体 控制 ， 如 设置 表格 的 style〈 样 式 ) 属性。 通过 将 表 
格 的 display 样式 设置 为 none， 可 以 控制 表格 的 隐藏 ， 将 表格 的 display 样式 设置 为 block， 可 以 显示 表格 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 编写 网 页 架构 ， 引 入 CSS 样式 表 和 JavaScript 脚本 ,编写 form 表单 ， 
代码 如 下 : 


<link type="text/ess" rel="stylesheet" href="css/in.css"/> 
<seript type="text/javaseript" sre="../js/jquery-1.3.2.js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
<table align="center"> 
<u> 
<td> 用 户 名 :</td> 
<td><input type="text"/></td> 
<lt> 
<u> 
<td> 密 &nbsp;&nbsp; 码 :</td> 
<td><input type="text"/></td> 
<i> 
<t> 
<td> 权 限 设置 </td> 
<td><input id="va" type="radio" name="ch" value="1" checked 放 超级 用 户 <input id="val" name="ch"type="radio" value="2" /> 普通 用 户 </td> 
</ltr> 
<tr> 
<td><table id="namel"><tr><td><input type="checkbox" /> 帖子 管理 </td></tr></table></td> 
<td><table id="name2"><tr><td><tr><td><input type="checkbox" /> 后 台 管理 </td></tr></table></td> 
<it> 
<t> 
<td><table id="name3"><tr><td><tr><td><input type="checkbox" /> 数 库 管 理 </td></tr></table></td> 
<td><table id="name4"><tr><td><tr><td><input type="checkbox" /> 公告 管理 </td></tr></table></td> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 ， 将 style 属性 动态 添加 到 复 选 框 的 表格 中 ， 控 制 表格 的 隐藏 和 显示 ， 代 码 


如 下 : 
S$(document) rcady(function0){ 
S("#va").click(functionO{ 
S("#name1").css("display","block"): 
$("#name2").css("display","block"); 
S$("#name3").css("display","block"): 
$("#name4").css("display", "block"): 


»): 
S$("#val").click(functionO{ 


S$("#name4").css("display"," 
了: 
D; 


国 秘笈 心 法 


心 法 领悟 171: 添加 CSS 属性 。 


利用 jQuery 框架 可 以 很 容易 地 将 属性 和 值 动态 地 添加 到 指定 标签 中 ， 语 法 格式 如 下 : 
S("class/id") .attr("key", "value"): 
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起 味 指教: 三 机 庚 | 


力 实例 说 明 


PHP 是 一 种 服务 器 端的 编程 语言 ， 顾 名 思 义 ， 在 需要 时 与 服务 器 进行 交互 并 且 处 理 信息 ， 但 是 很 多 时 候 ， 
用 户 希 望 在 与 服务 器 交互 之 前 就 完成 一 些 操作 , 这 个 时 候 客 户 端 脚本 语言 JavaScript 的 作用 就 体现 出 来 了 。 运行 
本 实例 ， 通 过 JavaScript 代码 实现 不 提交 表单 获取 单 选 按钮 的 值 ， 如 图 3.28 所 示 。 


3.28 不 提交 表单 获取 单 选 按钮 的 值 


图 关键 技术 


本 实例 主要 是 通过 JavaScript 代码 定义 click 事件 ,获取 单 选 按钮 的 值 ， 并 且 将 单 选 按钮 的 值 通过 <div> 标 签 
返回 到 页 面 中 ， 代 码 如 下 : 
S$(document) ready(function){ 
$(".n").mouseover(functionO{ 
$(".n").css({background:"#FFCCCC",border:"1px red solid"}); 
$(".n").mouseout(functionO){ 
S$(".n").css( {background:"white".border:"1px #00CCFF solid"}): 


DD; 
S$(".0").mouseover(functionO{ 
$(".0").css( {background:"#FFCCCC",border:"lpx red solid"}); 
$(".0") mouseout(finctionO{ 
S$(".0").css({background:"white",border:"1px #00CCFF solid"}); 


Dp: 
S$("#e").click(functionO{ 
S$("#nam") .css("display"."block"): 
var value = $("#e").val|: 
S$("#name").html(value): 
»D; 
$("#ee").click(functionO{ 
S$("#nam").css("display"."block"); 
var value = $("#ee").valO; 
S$("#name").html(value); 
D): 
D; 


力 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 ， 创 建 用 户 登录 的 form 表单 ， 设 置 文本 框 和 单 
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选 按钮 元 素 ， 并 且 设 置 <div> 标 签 定义 标签 的 ID 值 ， 核 心 代码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text javascript" sre="js/injs"></script> 
<table align="center"> 
<tr> 
<td> 用 户 名 : </td> 
<td><input class="n" type="text" /></td> 
</t> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <ltd> 
<td><input class="0" type="text" /></td> 
<lt> 
<t> 
<td><input id="e" name="ch"type="radio" value=" 保 存 密码 " /> 保存 密码 </td> 
<td><input id="ee" name="ch"type="radio" value=" 隐 身 登 录 " /> 隐身 登录 </td> 
</t> 
<tr> 
<td id="nam"> 单 选 按钮 值 为 : </td> 
<td><div id="name"></div></td> 
<> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 引 入 jQuery 库 文件 jquery-1.3.2.js。 
力 秘笈 心 法 


心 法 领悟 172: jQuery 中 的 click 事件 。 
当 单 击 标签 时 触发 此 事件 ， 语 法 格式 如 下 : 


S("class/id").click(fanctionO{...}): 


实例 173 趣味 指数 : 依依 疹 痕 


力 实例 说 明 


复 选 框 应 用 在 用 户 注册 系统 中 ， 如 个 人 爱好 选择 等 。 本 实例 所 讲述 的 3 个 操作 : 全 选 、 反 选 、 不 选 ， 只 是 
根据 实际 情况 ， 对 复 选 框 实现 的 快捷 操作 。 运 行 本 实例 ， 全 选 的 效果 如 图 3.29 所 示 。 


命 收 芯 本 站 ”加 设 为 首页 中 联系 我 们 


筷 程 司 丙 介绍 。 篇 程 司 奥 在 线 棱 务 


欢迎 光临 明日 科技 网 站 


| 会 员 信息 管理 
万 欧阳 PHP 部 门 缀 香 » 
隐 东方 JAVA 部 门 经 理 » 
万 夏侯 w 部 门 受理 » 
古 南宫 8B 部 门 受理 2 


技术 服务 热线 : 0431-84976981 34978962 
Copyright 回 www_aingrisoft_coa 如 1 Rights Reserved! 


图 3.29 实现 全 选 
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图 关键 技术 


复 选 框 的 全 选 、 反 选 和 不 选 主要 应 用 JavaScript 脚本 ， 通 过 自 定义 函数 完成 。 

(1) 在 通过 JavaScript 脚本 中 的 自 定义 函数 完成 复 选 框 的 全 选 、 反 选 和 不 选 功能 中 ， 应 用 的 第 1 个 方法 是 
getElementsByTagName， 获 取 指 定 标签 的 名 称 ， 返 回 值 为 一 个 包含 标签 信息 的 object。 

(2) 根据 getElementsByTagName 标签 返回 的 对 象 ， 判 断 标 签 类 型 〈type) 的 值 是 不 是 checkbox。 

(3) 当 标 签 类 型 type 的 值 为 checkbox 时 ， 为 标签 中 的 checked 赋值 。 当 checked 的 值 为 TRUE 时 ， 将 其 
赋值 为 FALSE; 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 

(4) 在 页 面 中 通过 script 标签 调用 js 文件 夹 中 的 文件 ， 应 用 onClick 事件 调用 自 定义 函数 ， 完 成 全 选 、 反 
选 和 不 选 功能 的 实现 。 


设计 过 程 
(1) 创建 js 文件 夹 ， 编 写 regjs 脚本 文件 。 在 regjs 文件 中 ， 编 写 自 定义 函数 ， 实 现 全 选 、 反 选 和 不 选 功 
能 。regjs 文件 的 关键 代码 如 下 : 


function uncheckAll(form] ,status) { // 不 选 
var elements = form] .getElementsByTagName('input ); // 获 取 input 标签 
for(var i=0; i<elements.length; i++){ /根据 标签 的 长 度 执行 循环 
if(elements[i] type 一 "checkbox) { // 判 断 对 象 中 元 素 的 类 型 
if(elements[i].checked—true){ // 判 断 当 checked 的 值 为 TRUE 时 
clements[i].checked=false; /| 将 checked 赋值 为 FALSE 
1 
} 
， 
function checkAll(forml,status) { // 全 选 


var clements = forml .getElementsByTagName('input ): 
for(var i=0; i<elements.length; i++){ 
if(elements[i].type — 'checkbox’) { 
这 elements[i].checked 一 false){ 
clements[i].checked=true; 
} 
} 
} 


} 
function switchAll(form!l ,status) { /反选 
var elements = forml .getElementsByTagName('input ); 
for(var i=0: i<elements.length: i++){ 
这 elements[i] type — ‘checkbox){ 
ielements[i].checked 一 tmue)f 
clements[i].checked=false: 
Yelse if(elements[i].checked—false){ 
clements[i].checked=true; 
} 


} 
} 


(2) 创建 index.php 页 面 ， 输 出 会 员 信息 ， 并 添加 图 像 按钮 ， 通 过 onClick 事件 调用 JavaScript 自 定义 函数 
实现 全 选 、 反 选 、 不 选 和 删除 的 功能 ， 其 关键 代码 如 下 : 


<script language="javascript" sre="js/reg.js"></script> 
<form method="post" name="forml" id="form1" action="index ok.php"> 
<tr> 
<td width="62" align="center"><input name="conn id[]" type="checkbox" id-"conn id[]" value="1" /></td> 
<td width="242"> 欧 阳 </td> 
<td width="243">PHP</td> 
<td width="485"> 部 门 经 理 </td> 
<td width="485">29</td> 
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< 

<tr> 

<td colspan="S" align="center"><!-- 通 过 onClick 事件 调用 自 定义 函数 ， 执 行 相应 的 操作 --> 
<img sre="images/bg_19-20.jpe" onclick="checkAll(forml ,status)" width="62" height="25" /> 
<img sre="images/bg_14-14.jpg" onclick="switchAll(forml ,status)"” width="62" height="25" /> 
<img sre="images/bg_07-08.jpg" width="62" height="25" onclick="uncheckAll(forml.status)" /> 
<input type="image" name="imageFicld" sre="images/bg_14.jpg” /> 

<htd> 

<lt> 

</form> 
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心 法 领悟 173: 复 选 框 的 全 选 、 反 选 和 不 选 的 实现 思路 。 

实现 复 选 框 的 全 选 、 反 选 和 不 选 操作 主要 应 用 JavaScript 脚本 ， 通 过 JavaScript 脚本 中 的 自 定义 函 数 ， 判 断 
复 选 框 中 checked 的 值 。 全 选 就 是 将 checked 赋值 为 TRUE， 不 选 则 是 将 checked 赋值 为 FALSE， 而 反选 则 是 当 
checked 的 值 为 TRUE 时 ， 将 其 赋值 为 FALSE; 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 


实例 说 明 


开发 在 线 论坛 系统 时 ， 在 回复 帖子 的 模块 中 ， 要 记录 是 谁 回复 了 哪 一 个 帖子 ， 即 要 把 这 个 回复 用 户 的 ID 同 
回复 帖子 的 内 容 一 起 保存 起 来 。 回 帖 的 内 容 是 从 文本 域 中 获取 的 ， 而 回帖 人 的 ID 则 是 通过 隐藏 域 进行 提交 的 ， 
不 需要 手动 填写 ， 如 图 3.30 所 示 。 


高 级 
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3.30 ”隐藏 域 提交 用 户 DD 


力 关键 技术 


本 实例 主要 应 用 表单 中 的 隐藏 域 来 实现 文件 值 的 提交 和 获取 。 
表单 中 隐藏 域 的 语法 格式 如 下 : 

<input type= "hidden" name="ID" value=""> 

参数 说 明 : 

type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 。 

name: 隐藏 域 的 名 称 ， 可 以 自己 定义 。 

value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 。 
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国 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 
如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<seript type="text/javaseript" sre=",./js/jquery-1.3.2js"></script> 
<seript type="text/javascript" sre="js/injs"></script> 
ie width op height="600px" backgroond-"picbeipe™> 
二 
<table align="center"> 


<t> 
<td> 回 帖 ，<input type="hidden" name="ID" value="1081" /></td> 
<> 


<t> 
<td> 标 题 : <input type="text” /></td> 
<ltr> 
<t> 
<td> 内 容 ，<textarea cols="30" rows="3"></textarea></td> 
<la> 
<tr> 
<td><input class="one" type="submit" name="sub" value="" /></td> 
</t> 
<tr><td id="name" style="display:none"> 
隐藏 域 值 为 ，<b id="b1"></b><br> 标 题 值 为 ，<b id="b2"></b><br> 内 容 值 为 <b id="b3"></b> 
<ltd></t> 
</table> 
<ltd> 
<ltr> 
</table> 


(2) 编写 JavaScript 脚本 ， 当 单 击 “ 回 帖 ” 按 钮 时 触发 事件 ， 代 码 如 下 : 
S$(document) ready(function(){ 
S(".one").click(functionO{ 
var vall = $("input:eq(0)").valO; 
var val2 = $("input:eq(1)").valO; 
Var val3 = $("textarea").val(); 
S$("#name").css("display","block"); 
$C"#b1").html(vall); 
$C"#b2").html(val2); 
$C"#b3"). html(val3); 

})): 

D; 


国 秘笈 心 法 


心 法 领悟 174: jQuery 中 使 用 $("").html0 方 法 的 注意 事项 。 
此 方法 是 取得 第 1 个 匹配 元 素 的 HIML 内 容 。 这 个 方法 不 能 用 于 XML 文档 ， 但 可 以 用 于 XHTML 文档 。 


实例 175 


趣味 指数 : 人 广 食 太 食 : 


力 实例 说 明 


在 很 多 网 站 的 主页 布局 中 ， 程 序 员 除了 在 导航 栏 中 布置 一 些 按钮 外 ， 在 网 页 的 主体 部 分 中 很 少 出 现 类 似 于 
提交 的 按钮 ， 这 样 做 的 主要 目的 并 不 是 因为 网 页 中 不 再 需要 按钮 ， 而 是 被 一 些 超 链接 或 者 图 像 域 跳 转 所 替代 。 
运行 本 实例 ， 当 单 击 图 片 时 实现 表单 提交 ， 如 图 3.31 所 示 。 
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国 像 注 花 代 提 交 按 钮 
村 是: | 贱 BRHF 


十 昕 了 件 有 限 公司 ， 生 一 下 

家 知名 企业 和 
内 容 : 大 人 
标题 ， 明 日 软件 内 容 ， 明 日 软件 有 限 公司 ， 是 一 
家 知名 企业 


图 3.31 图 像 域 蔡 代 提交 按钮 
图 关键 技术 


本 实例 主要 是 利用 JavaScript 代码 ， 通 过 单 击 事件 完成 数据 的 提交 操作 ， 其 关键 代码 如 下 : 
$(document)ready(function0O){ 


$("img").click(functionO{ 
var input = $("input").val(); 
Var textarea = $("textarea").val(); 
iflinput 一 ” || textarea — ""){ 
alert(" 文 本 框 为 空 "); 
jslse{ 
S$(".n").css("display","block"); 
S$("#i") html(input): 
S$("#t").html(textarea); 
D; 
D; 


图 设计 过 程 


(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" fisljquery-1.3.2js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
<table width="319" align="center"> 
<tr> 
<td width="296" class="oo"> 图 像 域 蔡 代 提交 按钮 </td> 
<ltr> 
<tr> 
<td> 标 题 ， <input type="text" /></td> 
<ltr> 
<tr> 


<td> 内 容 ，<textarea cols="20" rows="3"></textarea>&nbsp:&nbsp:<img sre="pic/img.gif" /></td> 
<ftr> 


> 
<td class="n"> 标 题 : <b id="i"></b> 内 容 : <b id="t*></b></td> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 js， 当 单 击 图 片 时 触发 事件 ， 代 码 如 关键 技术 所 示 。 
国 秘笈 心 法 
心 法 领悟 175: 图 像 域 的 使 用 。 


使 用 图 像 域 进 行 跳 转 和 提交 的 方式 有 很 多 。 例 如 嵌入 到 <a> 标 签 中 ， 进 行 客户 端 跳 转 ;或 者 应 用 在 form 表 
单 的 提交 、 重 置 按钮 中 。 灵 活 运 用 图 像 域 的 知识 会 使 程序 更 美观 。 
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| 


实例 176 趣味 指数 : 会 


力 实例 说 明 


跳 转 菜单 在 网 站 中 是 很 常见 的 ， 一 般 被 放置 在 靠近 头 部 的 位 置 ， 又 称 导 航 栏 。 下 面 就 讲解 如 何 实现 单 击 按 
钮 页 面 跳 转 的 效果 ， 如 图 3.32 所 示 。 


FANXING xs ex nn 1 


首页 | 注册 | 登录 
1 
四 SD RE py 
"mm 
口 标题 位 置 放置 处 1110 3320 和 
硬盘 联系 方式 
口 标题 位 置 放置 处 1110 3320 和 tr 了 
口 标题 位 置 放置 处 1110 3320 所 
a 硬盘 电子 图 书 
口 标题 位 置 放置 处 1110 3350 站 Wa 
口 标题 位 置 放 置 处 1110 3320 wa 
口 标题 位 置 放置 处 1110 3320 
口 标题 位 置 放置 处 1110 3320 
口 标题 位 置 放置 处 1110 3320 
共有 2 页 ,当前 是 第 1 页 [ee ee | 


服务 热线 : 0431-84978981 0431-84978982 Mtpywww mingrlsoftcom 


CopyrightBwww mingrisoft com All Fights Reservedl 


3.32” 跳 转 菜单 实现 页 面 跳 转 


力 关键 技术 


本 实例 主要 通过 <map> 定 义 跳 转 ， 代 码 如 下 : 

<map name="Map2" id="Map2"> 
<area shape="rect" coords="89,64,141.94" href="index.php?id=1" /> 
<area shape="rect" coords="168.64.229.94" href="index.php?id=2" /> 
<area shape="rect" coords="250,65.305.99" href="index.php?id=3" /> 
<area shape="rect" coords="328.63.388.97" href="index.php?id=4" /> 
<area shape="rect" coords="13.65.61.93" href="index.php" /> 

</map> 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 网 页 ， 通 过 <map> 定 义 页 面 跳 转 的 超 链 接 。 
(2) 编写 PHP 代码 ， 当 单 击 不 同 按钮 时 实现 跳 转 ， 代 码 如 下 : 
~ switch(s_GET[idD{ 
pie IPO 
Pm 


Case "2": 


echo "pic/log JPG"; 
break: 
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国 秘笈 心 法 
心 法 领悟 176: 如 何 取得 地 址 栏 参数 。 


以 本 实例 为 例子 ， 地 址 组 成 格式 如 下 所 示 ， 可 以 通过 $_GET 方式 取得 相应 的 参数 并 进行 操作 。 
http:// 地 址 /主页 .php? 参 数 & 参 数 


起 hp 高 级 


图 实例 说 明 


上 传 图 片 时 最 好 为 程序 设置 预览 功能 ， 防 止 用 户 意外 传 错 图 片 。 还 有 一 个 很 重要 的 模块 就 是 获取 图 片 的 地 
址 ， 方 便 用 户 网 站 的 推广 。 运 行 本 实例 ， 完 成 预览 图 片 和 获取 图 片 地 址 的 功能 ， 运 行 结果 如 图 3.33 所 示 。 


3.33 ”上 传 预 览 图 片 


力 关键 技术 


本 实例 通过 JavaScript 的 click 事件 ， 实 现 图 片 预 览 、 获 取 地 址 和 清除 上 传 文本 框 信息 的 功能 ， 其 核心 代码 
如 下 : 


S$(document) ready(fanction){ 
S$("#two").click(functionO{ // 单 击 预览 图 片 
Var value = $("#one").val(): // 取 得 上 传 地 址 
这 value 一 ”){f / 漳 断 地 址 是 否 为 空 
alert(" 地 址 为 空 "); 
jelsef 
S$(".n").append("<img id- five sre="+valuet+">"); // 显 示 图 片 
S("#two").click(fanctionO{ 
S$(".n").emptyO; 


S$(".n").append("<img id=five' sre="+valuet+">"): 


3 
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D; 
} 


Dp: 
S$("ihree") .click(functionO{ // 显 示 图 片 地 址 
var value = $("#one").val(); 
if(value — ""){ 
alert(" 地 址 为 空 "): 
Jelse{ 
alert(value): 
} 
D; 
S$("#four").click(functionO{ // 清 除 文本 框 信息 
$(".e").emptyO): 


SC ppend( np clos one ene type fie 
D): 
D; 


力 设计 过 程 


(1) 新 建 index.php 文件 ， 引 入 CSS 样式 、injs 文件 以 及 jQuery 库 文件 jquery-1.3.2js。 创 建 form 表单 ， 


设置 文件 域 属性 ， 添 加 预览 图 片 、 图 片 地 址 和 清除 的 按钮 代码 如 下 : 
<table width="600" height="450" align="center" background="pic/bgjjpg"> 
0 align="center"><div class="n"></div> 
<table align="center"> 
<tr> 


"><input class="one" id="one" type="file"></span> 
<input class="one" id="two" type=button value=" 预 览 图 片 "> 
<input class="one" id="three" type=button value=" 图 片 地 址 "> 
<input class="one" id="four" type=button value=" 清 除 " > 


</span> 
<itd> 
</tr> 
</table> 
<ltd> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关 键 技 术 。 
图 秘笈 心 法 


心 法 领悟 177: jQuery 框架 中 的 empty0 方 法 。 

empty0 方 法 : 删除 匹配 的 元 素 集 合 中 所 有 的 子 节点 ， 语 法 格式 如 下 : 
SCclass/id) .emptyO: 

参数 说 明 : 

class/id， 表 示 类 名 或 ID 名 称 。 


实例 178 


国 实例 说 明 


由 于 CSS 样式 对 下 拉 列 表 框 的 定义 很 少 , 以 至 于 想 要 修改 下 拉 列 表 框 的 样 
式 变 得 很 复杂 。 本 实例 将 讲解 如 何 去 掉 下 拉 列 表 框 的 边框 ， 如 图 3.34 所 示 。 


趣味 指数 : 宽广 食 食 


PHP 到 
[PHP 
ASP 


图 3.34 ”去掉 下 拉 列 表 框 的 边框 
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图 关键 技术 


本 实例 的 关键 点 是 严格 定义 CSS 样式 ， 代 码 如 下 : 
<div style="position: absolute: left: 10px: top: 10px: width: 115px: height: 20px: =clip:rect(2 114 20 2):"> 


图 设计 过 程 
创建 index.php 文件 ， 利 用 <table> 标 签 编写 表格 边框 。 编 辑 CSS 样式 ， 通 过 CSS 样式 去 掉 下 拉 列 表 框 的 边 
框 ， 代 码 如 下 : 


<table width="200px" height="100px" border="1" bordercolor="#0099FF" cellspacing="0"><tr><td> 
<div style="position: absolute; left: 10px: top: 10px; width: 115px: height: 20px: =clip:rect(2 114 20 2):"> 
<select> 
<option >PHP</option> 
<option >ASP</option> 
<option >JSP</option> 
</select> 
<ldiv> 
</td></tr></table> 


图 秘笈 心 ; 


心 法 领悟 178: CSS 的 效果 。 
像 上 面 这 样 较 为 生僻 的 代码 ， 其 实 笔者 也 不 能 够 完全 “吃透 ”， 但 是 没关系 ， 因 为 我 们 所 从 事 的 是 后 台 的 
开发 ， 前 台 的 东西 了 解 一 下 即 可 。 


实例 179 趣味 指数 : 妇女 


力 实例 说 明 


表单 可 以 添加 属性 并 且 与 客户 端 脚本 JavaScript 交互 ， 如 JavaScript 的 click、change 事件 等 。 运 行 本 实例 ， 
当 单 击 文本 框 时 弹出 提示 信息 ， 如 图 3.35 所 示 。 


如 果 在 编程 词 红 中 没有 您 需要 的 录像 ， 请 及 时 反 饥 给 我 们 ， 我 们 全 力 安排 专家 钉 / 
开发 视频 录 合 ， 并 及 时 升级 到 编程 词 红 录 创 中 。 


3.35 弹出 对 话 框 


力 关键 技术 
本 实例 主要 是 通过 JavaScript 代码 定义 单 击 事件 ， 核 心 代码 如 下 : 
S(document) ready(functionO{ 
SC"#o").click (fanctionO{ 


alert(" 文 本 框 被 单 击 "): 
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D; 
D; 


力 设计 过 程 


创建 index.php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 injs 和 jQuery 库 文件 jquery-1.3.2.js。 创 建 form 


<td> 用 户 名 : </td> 
<td><input id="0" type="text" /></td> 
<t> 
<t> 
<td> 密 &nbsp&nbsp: 码 : <ltd> 
<td><input id="o" type="text" onclick="alert(' 密 码 框 被 单 击 )"/></td> 
</t> 
</table> 


心 法 领悟 179: 定义 JavaScript 事件 。 


如 果 用 户 想 利用 JavaScript 本 身 的 方法 定义 事件 , 需要 在 表单 中 进行 , 代码 格式 如 实例 180 所 示 。 如果 是 利 


用 jQuery 框架 定义 事件 ， 只 需要 在 标签 中 定义 ID 或 者 类 即 可 。 
<input id="o"type="text" onlick=alert( 密码 框 被 单 击 J" 


实例 180 


高 级 | 
趣味 指数 : 去 去 去 去 | 


力 实例 说 明 
灵巧 的 CSS 是 所 有 Web 开发 者 追 氛 的 对 象 ， 其 主要 作用 是 通过 简单 的 代码 美化 页 面 ， 页 面 美化 用 CSS 基 

本 都 可 以 实现 。 本 实例 主要 讲解 通过 定义 CSS 样式 对 输入 单元 的 文字 进行 设置 ， 如 图 3.36 所 示 。 

上] 


用 户 名 : |asd 
客 码 : |asd 


图 3.36 动态 改变 文字 颜色 


图 关键 技术 
本 实例 的 关键 点 是 定义 CSS 样式 ， 通 过 JavaSeript 代码 动态 地 改变 文本 框 的 颜色 。JavaScript 代码 如 下 


<script type="text/javascript" language="javascript"> 


S$(document) ready(fanctionO{ 
S$("select").change(functionO{ 
var value = $("select").val(); 
iflvalue —"™"){ 
alert(" 请 选择 样式 颜色 "); 
Jelse{ 
S$("input:lt(2)").css("color",value); 
入 
六: 
</script> 
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力 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 CSS 样式 定义 一 个 无 边框 的 下 拉 列 表 框 ， 代 码 如 下 : 
<div style="position: absolute; left: 10px: top: 10px: width: 115px; height: 20px: -clip:rect(2 114 20 2):"> 
<select> 
<option value=""> 样 式 颜色 </option> 
<option value="red">red</option> 
<option value="blue">blue</option> 
<option value="yellow">yellow</option> 
‘</select> 
</div> 
(2) 编写 文本 框 和 密码 框 ， 代 码 如 下 : 
<div style="font-family:' 楷 体 _GB2312'; font-size:16px:"> 
用 户 名 : <input type="text" /><br> 
密 &nbsp;&nbsp; 码 : <input type="text" /> 
<div> 


(3) 编写 JavaSeript 脚本 文件 njs， 动 态 改变 文本 框 输入 单元 颜色 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 


心 法 领悟 180; jQuery 中 匹配 所 有 小 于 给 定 索引 值 的 元 素 。 
例如 ，$("tr:It(2)") 表 示 匹 配 <t> 标 签 中 小 于 索引 值 2 的 元 素 。 


高 级 


趣味 指数 : 女友 二 让 | 


实例 181 


实例 说 明 
在 创建 表单 中 的 文本 框 等 内 容 时 ， 往 往 会 给 文本 框 设 定 初始 值 ， 这 些 初始 值 需要 用 户 自行 手动 删除 。 为 了 


方便 用 户 ， 节 省 操作 时 间 ， 可 以 通过 设置 JavaScript 事件 ， 实 现 直接 删除 文本 框 中 初始 值 的 功能 。 运 行 本 实例 ， 
效果 如 图 3.37 所 示 。 


如 果 在 编程 词 弥 中 没有 您 需要 的 录像 ， 请 及 时 反 钱包 我 们 ， 我 们 全 力 安 徘 专家 制 | 
天 发 视频 好 全 ， 并 及 时 升级 到 妨 香 词典 录像 中 。 


3.37 表单 输入 单元 单 击 删除 


图 关键 技术 
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alert( 清 除 文本 框 信息 ): 


S(vtcxtarcan) click(function0{f 
Sthisjattr(valuen 


D: 

D; 
力 设计 过 程 

创建 index.php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 injs 和 jQuery 库 文件 jquery-1.3.2.js。 编 写 表单 
信息 ， 代 码 如 下 : 


<table align="center"> 
<t> 


<td> 标 题 : </td> 
<td><input type="text" value=" 请 输入 标题 " /></td> 
<lt> 
<tr> 
<td> 内 容 : </td> 
<td><textarea cols="23" rows="3"> 请 输入 内 容 </textarea></td> 
</tr> 
<htable> 


图 秘笈 心 法 


心 法 领悟 181， 如 何 简单 实现 本 实例 功能 。 
本 实例 是 采用 jQuery 框架 实现 的 ， 书 写 代 码 较 多 ， 还 有 一 种 简便 方法 是 在 表单 中 直接 定义 onFocus 事件 ， 
代码 如 下 : 


<input type='text name='te' value=' 请 输入 内 容 ' onFocus="this.value=""> 


高 级 
趣味 指数 : 容 机 全 贾 


实例 说 明 


很 多 网 站 中 往往 有 一 些小 的 技巧 ， 例 如 ， 在 文本 域 中 输入 内 容 时 ， 通 过 下 拉 列 表 框 动态 地 将 文字 插入 文本 
域 中 。 下 面向 用 户 讲述 这 一 功能 。 运 行 本 实例 ， 效 果 如 图 3.38 所 示 。 


如 果 在 编程 词 织 中 没有 您 需要 的 录像 ， 请 及 时 反馈 论 我 们 ， 我 们 全 力 安排 专家 岸 | 
开发 视频 录像 ， 并 及 时 升级 到 编程 词典 录像 中 。 


图 3.38 表单 文本 输入 的 移动 选择 


力 关键 技术 
本 实例 通过 JavaScript 脚本 中 的 change 事件 ， 实 现 动态 插入 信息 ， 其 核心 代码 如 下 : 
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S$(document) ready(functionO{ 
S$("textarea").select(); /选择 下 拉 列 表 框 
S$("select").change(functionO{ // 定 义 事件 
var value = $(this).val(); /获取 value 值 
var va = $("textarea").val(); /获取 文本 域 的 值 
这 va 一 "请 输入 内 容 "){ 
S$("textarea").html(value); // 输 出 文本 域 的 值 
Jelse{ 
S$("textarea").html(vatvalue); // 为 文本 域 赋值 
D: 
D; 
图 设计 过 程 


(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs， 以 及 jQuery 库 ， 创 建 下 拉 列 表 框 和 
文本 域 ， 代 码 如 下 : 


<table align="center"> 
<t> 
<td><select name="select"> 
<option value=" 谢 谢 "> 谢谢 </option> 
<option value=" 不 客气 "> 不 客气 </option> 
<option value=" 有 空 常 来 玩 "> 有 空 常 来 玩 </option> 
<option value=" 再 见 "> 再 见 </option> 
</select></td> 
<itr> 
<b> 
<td><textarea cols="20" rows="3"> 请 输入 内 容 </textarea></td> 
<it> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 
心 法 领悟 182: 如 何 利用 jQuery 实现 文本 框 内 容 全 选 。 


实现 文本 框 内 容 全 选 与 单 击 文本 框 清除 所 有 信息 所 达到 的 效果 大 同 小 异 ， 其 实现 代码 如 下 
S$("textarea").select(); 


ee i 有 | 
趣味 指数 : 容 窒 页 让 | 
看 实例 说 明 


在 腾讯 的 QQ 系统 中 ， 可 以 通过 单 击 头像 实现 更 换 新 头像 的 功能 。 其 实 这 个 功能 相对 来 说 是 比较 简单 的 。 
运行 本 实例 ， 通 过 下 拉 列 表 框 实现 头像 的 选择 ， 如 图 3.39 所 示 。 


图 3.39 选择 头像 
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图 关键 技术 


本 实例 通过 JavaScript 的 change 事件 和 实例 162 中 的 2 级 联动 菜单 实现 ， 其 核心 代码 如 下 : 
S$(document) ready(functionO){ 
S$("select").change(functionO{ 
var value = $(this).val(); 
这 value 一 "){ 
alert(" 请 选择 性 别 "); 
Jelse{ 
iflvalue — "nan"){ 
S("#0").empty(); 
S$("#o").append("<select id-'onc><option valuc=pic/1jpg> 头 像 1</option><option value='pic/2.jpg> 头 像 2</option><option 
value='pic/3.jpg> 头 像 3</option><option value='pic/4.jpg> 头 像 4</option><option value='pic/9.jpg> 头 像 5</option></select>"); 
S("#n").empty(0); 
S("#n").append("<img sre=pic/1 jpg>"); 
S$("#one").change(functionO{ 
var va = $(this).val(); 
S$("#n").emptyO; 
S$("#n").append("<img sre="+vat">"); 
ba 
jelse{ 
S$("#o").emptyO; 
$("#o").append("<select id-'one><option value='pic/5.jpg> 头 像 1</option><option value='pic/6.jpg> 头 像 2</option><option 


value=pic/7jpg> 头 像 3</option><option value='pic/8.jpg> 头 像 4</option><option value= pic/10jpg> 头 像 5</option></select>"); 
$ empty(): 
和 .append("<img sre='pic/$.jpg>"); 
S$("#one").change(function() { 
var va = $(this).val(): 
S("#n").emptyO); 


S("#n").append("<img sre="+vat">"); 
D; 


} 
外 
»); 


图 设计 过 程 
(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs， 以 及 jQuery 库 ， 编 写 下 拉 列 表 和 标 
签 ， 代 码 如 下 : 


<table align="center"> 
<tr> 
<td> 
<select name="select"> 
<option value=""> 请 选择 性 别 </option> 
<option value="nan"> 男 性 </option> 
<option value="nv"> 女 性 </option> 
‘</select> 
<div id="0"></div><div id="n"></div> 
<ltd> 
<ltr> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 183: jQuery 中 的 this 关键 字 。 
jQuery 中 的 this 关键 字 与 其 他 编程 语言 大 致 相同 ， 此 关键 字 表示 当前 方法 体 的 类 名 称 或 者 ID 和 标签 , 书写 
格式 如 下 : 


varva=Sdthis)val0: 
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3.5 ”CSS+DIV 页 面 布局 


CSS+DIV 是 一 种 网 站 的 标准 或 称 面向 Web 的 标准 ) 中 常用 术语 之 一 ， 通 常 是 为 了 说 明 与 HTML 页 面 中 
的 表格 〈table) 定位 技术 的 区 别 ， 或 者 是 因为 HTML 网 站 设计 标准 中 不 能 使 用 表格 定位 技术 ,而 采用 CSS+DIV 
方式 实现 的 各 种 定位 。 


高 级 
起 叶 指数 砍 克 克 友 


实例 184 


图 实例 说 明 


对 于 一 个 页 面 风格 清新 自然 的 网 站 来 说 , 如 果 打开 的 窗口 带 有 不 适合 页 面 风格 的 灰色 边框 及 死板 的 标题 栏 ， 
不 但 不 能 体现 其 个 性 化 ， 而 且 势 必 会 影响 网 站 的 整体 效果 。 本 实例 介绍 一 种 应 用 CSS+DIV 实现 的 无 边框 窗口 。 
运行 本 实例 ， 单 击 “ 用 户 登 录 ” 超 链接 ， 即 可 打开 无 边框 的 用 户 登 录 窗 口 ， 如 图 3.40 所 示 。 


3.40 无 边框 窗口 


力 关键 技术 


本 实例 通过 CSS+DIV 排版 定位 技术 ， 将 表格 放置 在 指定 位 置 ，CSS 代码 如 下 : 


60 


Se ilbaed -ipg): 
#NOborder{ 
clear:left; 


float:right: 
position:absolute; 
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margin-right:10px; 
width:200px; 
height:100px; 
margin:auto; 

} 

#border{ 
width:auto: 
height:100px: 

了 


margin: 
width:80px; 
height:20px: 
} 


利用 JavaScript 代码 实现 表格 的 显示 或 隐藏 ，JavaScript 代码 如 下 : 
S$(document) ready(function(){ 
$("a").click(functionO{ 

S$("table").css("display", "block");: 


D); 

S$("#two").click(functionO{ 
S$("table").css("display". "none"); 

D); 

D; 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 和 JavaScript 脚本 文件 ， 通 过 <div> 标 签 对 网 页 进行 布局 ， 编 
写 无 边框 表格 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" sre: sljquery-1.3.2.s"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 


<a href="#"> 用 户 登录 </a> 
</div> 
</div> 
<div id="NOborder"> 
<table border="1" bordercolor="#999999" cellspacing="0"><tr><td> 
<table> 
<tr> 
<td> 一 用 户 登录 一 </td> 
<itr> 
<u> 
<td> 用 户 名 ;<input type="text" size="10"/></td> 
<ltr> 
<tr> 
<td> 密 &nbsp:&nbsp; 码 : <input type="text" size="10" /></td> 
<t> 
<t> 
<td><input id="one" value="" type="button" /><input id="two” value="" type="button" /></td> 


(2) 编写 CSS 样式 文件 in.css 和 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 
心 法 领悟 184: CSS 中 position 关键 字 的 使 用 。 
position 关键 字 用 于 检索 对 象 的 定位 方式 ， 其 属性 值 如 下 : 


223 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


static: 无 特殊 定位 ， 对 象 遵循 HTML 定位 规则 。 

absolute: 将 对 象 从 文档 流 中 拖 出 , 使 用 left、right、top、bottom 等 属性 进行 绝对 定位 , 而 其 层 肢 通过 z-index 
属性 定义 。 此 时 对 象 不 具有 边 距 ， 但 仍 有 补 白 和 边框 。 

relative: 对 象 不 可 层 合 ， 但 将 依据 left、right、top、bottom 等 属性 在 正常 文档 流 中 偏 移 位 置 。 

fixed: IE 5.5 及 NS 6 尚 不 支持 此 属性 。 


力 实例 说 明 


表格 在 Web 开发 中 很 常见 ， 很 多 程序 员 都 喜欢 利用 表格 对 自己 数据 库 中 的 信息 进行 格式 输出 。 但 是 表格 在 
默认 情况 下 ， 无 论 从 色调 还 是 格式 上 都 不 是 很 理想 ， 这 就 需要 程序 员 利 用 CSS 的 知识 对 其 样式 进行 设置 。 运 行 
本 实例 ， 效 果 如 图 3.41 所 示 。 


2010-08-12 
2010-08-23 
2010-07-06 


图 3.41 设置 表格 样式 


力 关键 技术 
本 实例 利用 CSS 样式 ， 对 表格 的 边框 、 背 景色 等 进行 设置 ， 核 心 代码 如 下 : 
body{ 


margin-top:150px; 
} 


如 of 
margin-left:150px; 


} 

table.select{ 
font-family:" 楷 体 _GB2312"; 
font-size:16px: 


} 


table{ 
background:#32ACEF: 
td{ 

text-align:center; 

} 


.one{ 
background:#FFFFFF: 
} 


四 设计 过 程 


<img sre="pic/bannerjpg” /> 
</div> 
<divid="e"> 
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<table width="575" border="1" bordercolor-"#7DDSFA" cellspacing="0"><tr><td> 
<table width="575px"><tr> 
<td> 用 户 ID</td> 
<td> 用 户 名 <htd> 
<td> 密 码 </td> 
<td> 操 作 时 间 </td> 
<ltr> 
<tr class="one"> 
<td>001</td> 
<td>ym</td> 
<td>***#</td> 
<td>2010-08-12</td> 
<lt> 
<tr class="one"> 
<td>002</td> 
< td> 
<td>***</td> 
<td>2010-08-23</td> 


<td>2010-07-06</td> 
</t> 
</table></td></tr></table> 


(2) 编写 CSS 样式 ， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 185: 使 用 CSS 中 margin 关键 字 的 注意 事项 。 

(1) margin 关键 字 主要 用 于 检索 和 设置 对 象 四 边 的 外 沿边 距 ， 此 关键 字 根据 传 入 参数 的 不 同 ， 性 能 也 不 相 
同 。 如 果 提 供 全 部 的 4 个 参数 值 ， 将 按 上 、 右 、 下 和 左 的 顺序 作用 于 四 边 ， 如 果 只 提供 1 个 参数 ， 将 用 于 全 部 
的 四 边 ， 如 果 提 供 2 个 参数 ， 第 1 个 用 于 上 和 下 ， 第 2 个 用 于 左 和 右 ， 如果 提供 3 个 参数 ， 第 1 个 用 于 上 ， 第 
2 个 用 于 左 和 右 ， 第 3 个 用 于 下 。 

(2) 内 联 对 象 要 使 用 该 属性 ， 必 须 先 设 定 对 象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 
在 IE 4+ 中 ，margin 属性 不 可 用 于 td 和 人 对 象 。 

(3) 外 延边 距 始终 透明 。 


5 高 级 
an | Bee 


力 实例 说 明 


CSS 之 所 以 受到 很 多 Web 设计 者 的 追捧 ， 是 因为 它 几乎 可 以 实现 所 有 的 基础 美化 功能 ， 图 片 当然 也 不 例 
外 。 运 行 本 实例 ， 应 用 CSS 样式 实现 图 片 向 左 和 向 右 浮动 、 为 图 片 添加 边框 的 功能 ， 运 行 结果 如 图 3.42 所 示 。 


他 ， 劣 人 都 喜欢 他 ， 他 的 名 字 叫 做 阿 几 提 。 


3.42 设置 图 片 的 样式 
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图 关键 技术 


本 实例 主要 通过 JavaScript 代码 动态 地 为 图 片 添加 CSS 样式 ， 核 心 代码 如 下 : 
S$(document) ready(functionO{ 
S$("select").change(functionO{ 
var value = $(this).val|); 
if(value —""){ 
alert(" 您 没有 选择 图 片 样式 "); 
jelsef 
if(value — D){ 
S$("img").css("float"."left"): 
}else{ 
这 value 一 2{f 
S("img").css("float","right"); 
Jelse{ 
S$("img").css({border:"1px red solid"}): 


了 
} 
D); 
D; 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 下 拉 列 表 框 和 
内 容 主体 ， 代 码 如 下 : 
<div> 
<table border="1" bordercolor="#00CCEF" ellspacing="0"><tr><td> 
‘<select> 
<option value="> 请 选择 图 片 样式 <joption> 
<option value="1"> 图 片 向 左 浮动 </option> 
<option value="2"> 图 片 向 右 浮动 </option> 
<option value="3"> 为 图 片 添加 边框 </option> 
</select> 
<ltd></tr><tr><td> 
<img sre="pic/img.gif' /> 
&nbsp;&nbsp:&nbsp:&nbsp: 很 久 很 久 以 前 ， 在 中 国 新 疆 地 区 ， 有 一 个 骑 着 毛驴 的 中 年 男人 ， 听 说 他 智慧 过 人 ， 爱 打 抱 不 平 ， 经 常 为 了 
老百姓 的 利益 与 达官 贵人 进行 智慧 的 较量 。 而 且 他 胆量 非凡 ， 总 是 戏弄 那些 达官 显贵 。 在 那里 富 人 都 害怕 他 ， 穷 人 都 喜欢 他 ， 他 的 名 字 叫 做 阿 
凡 


提 
</td></tr></table></div> 


(2) 编写 JavaScript 脚本 ， 代 码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 186: CSS 中 如 何 使 用 float 属性 。 

float 属性 指定 对 象 是 否 浮动 和 如 何 浮动 等 ， 参 数 如 下 : 
回 nne: 对 象 不 浮动 。 

left， 对象 浮 在 左边 。 

right: 对 象 浮 在 右边 。 


高 级 
趣味 指数 : 真人 广 丛 三 


| 
: 


力 实例 说 明 


用 户 在 设计 页 面 时 ， 为 了 达到 整体 协调 的 效果 ， 很 多 时 候 需要 重新 设计 滚动 条 。 本 实例 只 是 更 改 了 滚动 条 
相关 的 色调 ， 没 有 对 其 整体 效果 进行 更 改 ， 运 行 效果 如 图 3.43 所 示 。 
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美食 教程 


下 然 咎 用 】 : 牛肉 一 盘 ， 孜 热 少许 放 入 牛 内 及 调味 刑 ， 小 中 炎 炒 名 再 族 入 孜 兰 即 可 和 全。 
| Ri | 中 


3.43 ”滚动 条 样式 


力 关键 技术 
本 实例 通过 CSS 样式 对 浏览 器 的 滚动 条 等 颜色 进行 更 改 ， 核 心 代码 如 下 : 


td{font-size:9pt} 

BODY { 

SCROLLBAR-BASE-COLOR: #FFADO00:; 
SCROLLBAR-FACE-COLOR: #FFCB29}; 
SCROLLBAR-ARROW-COLOR: #800529; 
SCROLLBAR-TRACK-COLOR: #EEFFCC:; 
SCROLLBAR-DARKSHADOW-COLOR:#FFFFFF:; 
} 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 页 面 ， 载 入 CSS 样式 ， 其 关键 代码 如 下 : 


<link href="css/style.css" rel="stylesheet"> 


(2) 编写 CSS 样式 文件 style.css， 代 码 见 关键 技术 。 
图 秘笈 心 法 
心 法 领悟 187: CSS 中 设置 color 属性 的 注意 事项 。 


color 为 要 设置 的 颜色 代码 ， 可 以 是 十 六 进 制 的 ， 如 红 F0000， 也 可 以 是 以 RGB 表示 的 ， 如 RGB (255，0， 
255) 。 在 设置 滚动 条 样式 时 ， 不 必 把 所 有 的 属性 都 用 上 ， 用 户 可 根据 网 页 的 需求 自行 设置 。 


a 
an | | 


i 
力 实例 说 明 


表单 几乎 是 所 有 网 站 都 不 可 或 缺 的 一 个 模块 ， 用 户 可 以 用 它 登录 到 网 站 或 者 填写 个 人 信息 等 。 所 以 对 于 
一 个 Web 开发 者 来 说 ， 学 习 设 置 一 个 优秀 的 表单 样式 是 很 重要 的 。 运行 本 实例 ,通过 CSS 设置 表单 样式 ， 效 
果 如 图 3.44 所 示 。 


3.44 设置 表单 样式 
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力 关键 技术 
本 实例 通过 CSS 样式 对 表单 的 字体 、 标 签 、 文 本 边框 进行 设置 ， 实 现 美化 的 目的 ， 代 码 如 下 : 


margin-top:150px 

} 

#one{ 

margin-left:400px; 
font-family:" 楷 体 GB2312"; 
font-size:16px; 

} 

input{ 

width:150px; 

} 

#e{ 

width:35px: 
background-image:url(../pic/buttom.jpg); 
border:0; 

} 

tee{ 

width:35px: 
background-image:url(../pic/buttom1 jpg): 
border:0; 

; 

#o#n{ 

border:1px #FFCCFF solid; 

} 

table{ 

width:250px: 

height:150px; 
background-image:url(../pic/bg:jpg); 


} 
另外 还 应 用 JavaScript 特效 ， 使 鼠标 覆盖 或 移出 时 文本 框 变 色 ， 代 码 如 下 : 
S$(document) ready(functionO{ 
$("input:lt(2)").mouseover(functionO{ 

S(this).css("background","#BFAFC9"); 

S(this).mouseout(functionO{ 

S(this).css("background", "white"); 
D: 


D: 
D; 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 、JavaScript 脚本 文件 和 jQuery 类 库 文件 ， 通 过 <div> 定 位 技术 对 
表格 信息 进行 定位 。 创 建 form 表单 ， 设 置 用 户 名 和 密码 文本 框 ， 代 码 如 下 : 


<link type="text/ess" rel="stylesheet" href="css/in.css"/> 

<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text/javascript" sre="js/in.js"></script> 

<div> 

<div id="one"> 

<table border="1" bordercolor="#00CCFF" cellspacing="0"><tr><td> 
用 户 名 : <input type="text" id="o" /><br> 

密 &nbsp:&nbsp: 码 :<input type="password" id="n" /><br> 

<input type="button" id="e" valuc=""/><input type="button" id="ee" valuc=""/> 
</ltd></tr></table> 

</div> 

<div> 


(2) 编写 CSS 样式 和 JavaScript 脚本 ， 代 码 见 关键 技术 。 
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心 法 领悟 188: CSS 中 设置 border 属性 的 注意 事项 。 

border 属性 是 复合 属性 ， 如 使 用 该 复合 属性 定义 单个 参数 ， 则 其 他 参数 的 默认 值 将 无 条 件 覆 盖 各 自 对 应 的 
单个 属性 设置 ， 默 认 值 为 medium none。border-color 的 默认 值 将 采用 文本 颜色 。 要 使 用 该 属性 ， 必 须 先 设 定 对 
象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 


实例 189 


力 实例 说 明 


超 链 接 在 Web 开发 中 也 是 很 常见 的 ， 其 主要 作用 是 执行 客户 端的 脚本 跳 转 。 默 认 情 况 下 ， 单 击 之 前 颜色 为 
蓝 色 ， 存 在 下 划 线 样式 ， 单 击 之 后 颜色 为 紫色 ， 同 样 存在 下 划 线 样式 。 但 是 这 种 样式 不 可 能 适合 所 有 的 网 站 色 
调 。 本 实例 介绍 如 何 更 改 超 链 接 的 样式 ， 运 行 效果 如 图 3.45 所 示 。 


图 3.45 设置 超 链接 的 样式 


力 关键 技术 
本 实例 通过 CSS 样式 ， 定 义 <a> 标 签 的 3 个 属性 ， 控 制 超 链接 的 样式 ， 其 核心 代码 如 下 : 
af 


border:1px #FF0000 solid; 
} 

alink{ 

color:#333333; 
text-decoration:none: 


} 

arvisited{ 

color:#666666; 
text-decoration:none; 

} 

a:hover{ 
background-color:#FF0000; 
color#FFFFFF; 

} 


力 设计 过 程 


(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 ， 编 写 5 个 超 链 接 ， 代 码 如 下 
<div> 
<div id="one"> 
<table border="1" bordercolor="#00CCFF" cellspacing="0" background="pic/bg.ipg"><tr><td> 
<a hre 仁 "#"> 链 接 1</a>&nbsp;<a hre 仁 "# > 链接 2</a>&nbsp:<a hre 仁 "#" > 链接 3</a>&nbsp;<a hre 仁 "#"> 链 接 4</a>&nbsp:<a hre 仁 "#"> 链 接 
4</a>&nbsp:<a href="#"> 链 接 5</a> 
<htd></tr></table> 
</div> 
</div> 


(2) 编写 CSS 样式 ， 代 码 见 关 键 技术 。 
秘笈 心 法 
心 法 领悟 189: 定义 <a> 标 签 的 3 个 属性 。 
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:link: 设置 a 对 象 在 未 被 访问 前 的 样式 表 属 性 。 
:visited: 设置 a 对象 在 其 链接 地 址 已 被 访问 时 的 样式 表 属 性 。 
:hover: 设置 对 象 在 鼠标 悬 停 时 的 样式 表 属 性 。 


eeooosooeeoooooeeoseeoopooooeeooeeooeeooeooeooeoooesooeooneoeeooeeleon enontens 
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力 实例 说 明 


HTML 将 整个 网 页 分 成 头 部 (head) 和 身体 (body) 两 个 部 分 ， 头 部 一 般 包 含 标题 和 引入 的 JavaScript 和 
CSS 样式 等 ; 身体 部 分 主要 是 执行 的 代码 ， 其 中 可 以 包含 表格 、 表 单 和 <div> 标 签 等 元 素 。 对 于 <body> 中 的 元 素 
可 以 进行 CSS 的 样式 美化 ， 但 是 如 果 用 户 想 定义 类 似 全 文 的 一 个 文字 的 样式 ， 则 需要 对 每 个 标签 里 输出 到 页 面 
的 文字 进行 CSS 样式 的 定义 ， 这样 未 免 太 麻烦 ， 因 此 可 以 在 <body> 标 签 中 应 用 CSS 样式 ， 这 样 就 可 以 对 整个 页 
面 中 的 文字 进行 设置 ， 运 行 结果 如 图 3.46 所 示 。 


提供 源码 彻底 查询 ， 快 速 查找 相关 技术 的 顶 
目 应 用 ， 通 过 源 程序 按钮 ， 可 快速 打开 源 程 


D> Fi 


图 3.46 设置 body 的 样式 


图 关键 技术 


本 实例 通过 定义 <body> 标 签 的 CSS 样式 ， 对 整个 页 面 中 的 文字 及 文字 的 颜色 进行 定义 ， 其 核心 代码 如 下 : 


body{ 
font-family:" 楷 体 _GB2312"; 
font-size:14px: 
color:#666666: 

} 


图 设计 过 程 
(1) 创建 index.php 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 
代码 如 下 : 
Es 
‘<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
‘<table width="595px" height="448px" align="center" border="1" bordercolor="#0099FF" cellspacing="0" background="pic/bg.ipg"> 


<td> 用 户 名 : <input type="text" id="o" /></td> 
<ltr> 
<tr> 
<td> 密 &nbsp:&nbsp: 码 : <input type="password"” id="0"/></td> 
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<ftr> 
</table> 
<itd> 

<ltr> 
</table> 


(2) 编写 CSS 样式 和 JavaScript 脚本 文件 ， 核 心 代码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 190: 定义 <body> 标 签 属性 的 注意 事项 。 
当 用 CSS 样式 定义 了 <body> 标 签 后 ， 如 果 想 定义 <body> 内 的 元 素 属 性 ， 需 要 对 每 个 元 素 进行 更 改 。 


二 
| | 
ee eee. | 
图 实例 说 明 
在 一 些 大 型 网 站 的 首页 中 ， 为 了 体现 动画 效果 ， 通 常 在 进入 首页 前 添加 一 个 模拟 的 进度 条 ， 通 过 该 进度 条 


实现 打开 网 站 首页 的 前 奏 。 运 行 本 实例 ， 将 自动 加 载 一 个 模拟 的 进度 条 ， 运 行 结果 如 图 3.47 所 示 。 当 进度 条 完 
成 100% 后 ， 自 动 跳 转 到 http://www.mingrisoft.com 网 站 。 


图 3.47 模拟 的 进度 条 


力 关键 技术 


本 实例 主要 应 用 for 循环 语句 控制 进度 条 的 进度 ， 当 进度 条 完成 整个 进度 的 显示 时 ， 自 动 调用 finish0 函 数 ， 
从 而 跳 转 到 指定 的 网 站 。 
另外 ， 本 实例 中 进度 条 的 样式 是 通过 CSS 样式 设置 的 ， 并 应 用 div 层 输出 到 浏览 器 。 


图 设计 过 程 
(1) 应 用 CSS 样式 设置 div 层 及 文字 的 样式 ， 代 码 如 下 


<style type="text/css"> 
div {font-size: 9pt} 

#load {font-size: Opt: cursor: default position: absolute: display:block:width:402:height:20:top:expression((document.body.clientHeight-50)/2); 
left:expression((screen.width-400)/2); display: block: z-index:100:background:#EDECE9} 

.px1 {border: 1px solid :background-color: #FFFFFF:} 


body { 
background-color: #000000: 


} 
.stylel {color: #FFFF00} 
</style> 


(2) 在 <body> 中 应 用 div 层 设计 进度 条 ， 应 用 class 为 div 层 引 用 已 定义 的 CSS 样式 ， 并 添加 部 分 说 明文 


字 ， 然 后 应 用 for 循环 语句 限制 进度 条 完成 整个 进度 的 行程 ， 代 码 如 下 : 
<body onload=finishO> 
<div id-load style="background-color:#000000"><span class="style1"> 请 稍 候 .</span> 
<div class=pxl><img id=line style="background:red" width=14 height=14></div> 
<div class="style1" id=load_txt>loading</div> 
<div> 
<?php 
for(Si=0:Si<500:Sit+H)f 
> 
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<script>load_num("Loading"):</script> 
<Iphp 
<lbody> 
(3) 应 用 JavaScript 脚本 实现 进度 条 的 动态 效果 , 当 进度 条 完成 整个 进度 的 显示 时 ,自动 调用 finish0 函 数 ， 
从 而 跳 转 到 指定 的 网 站 ， 代 码 如 下 : 
<script language=JavaScript> 
var load line i=1; 


var load line_step=500; 

function load_num(txt) 

{load_line i+=400/load line_step; 

load_txtinnerText=txt+" "+Math.floor(load line i/4.00)+"%6"; 


window, i /fwww.mingrisoft.com"; 
} 


<lscript> 


图 秘笈 心 ; 


心 法 领悟 191: JavaScript 脚本 客户 端 跳 转 的 两 种 形式 。 
当 页 跳 转 : 

window.location href="http:// " 

新 页 跳 转 : 


Window.open="http:/" 


高 级 
起 叶 指 才 :页 克 页 
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力 实例 说 明 


在 进行 网 页 排版 时 ， 用 户 可 以 使 用 <table> 标 签 进行 布局 ， 但 是 在 比较 大 的 网 页 中 ， 用 <table> 标 签 布局 会 使 页 
面 代码 变 得 混乱 , 不 容易 解读 , 所 以 笔者 建议 尽量 使 用 <div> 标 签 进 行 页 面 布局 。 运行 本 实例 , 效果 如 图 3.48 所 示 。 


提供 源码 彻底 查询 ， 快 速 查 找 相 关 技 术 的 项 
目 应 用 ， 通 过 源 程 序 按钮 ， 可 快速 打开 源 程 
有 序 ， 方 丁 详 歼 。 


图 3.48 ”<div> 标 签 设计 用 户 注册 页 面 


图 关键 技术 
本 实例 的 关键 点 是 对 <div> 标 签 定位 的 灵活 运用 ， 及 运用 CSS 样式 控制 页 面 的 样式 ， 核 心 代码 如 下 : 
deg 
text-align:center; 
} 
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one{ 
margin-top:100px; 
width:595px; 

height:448px: 
background:url(../pic/bg:jpe); 
} 

input{ 

width:150px; 

height:18px; 

border-left:0; 

border-top:0; 

border-right:0; 
border-bottom: lpx #CCCCCC solid: 
background:#6BACCC; 

} 

two{ 

margin-top:200px; 
margin-left:200px; 
font-family:" 楷 体 _GB2312"; 
font-size:16px 
color#0000FF: 

} 

#pic{ 

border:0; 
background:url(../pic/btjpe): 
width:39px; 

} 


‘three{ 
margin-right:170px; 
} 


力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 排版 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 
如 下 : 


<div class="one"> 
<div class="two"> 
<div> 
上 昵称: <input type="text" /> 


密码 ，<input type="password" /> 
QQ: <input type="text" /> 


住址 ，<input type="text" /> 
</div> 
<div class="three"> 
<input id="pic" type="submit" value="" /> 
</div> 
</div> 
<div> 


(2) 编写 CSS 样式 ， 设 置 文本 标签 和 标签 位 置 定位 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 
心 法 领悟 192: 如 何 定义 文本 框 只 显示 为 一 条 下 划 线 的 CSS 样式 风格 。 


使 文本 框 只 显示 为 一 条 下 划 线 的 操作 很 简单 ， 其 原理 是 将 文本 框 的 左 、 右 、 上 边框 的 border 属性 都 设置 为 
0， 然 后 定义 下 边框 的 CSS 样式 。 以 本 实例 为 例 ， 代 码 如 下 : 


border-left:0: 
border-top:0: 

border-right:0: 

border-bottom: 1px #CCCCCC salid: 
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实例 193 


力 实例 说 明 


论坛 的 浏览 页 面相 信 对 于 所 有 用 户 来 说 并 不 陌生 , 其 主要 功能 是 将 用 户 发 表 的 内 容 供 所 有 人 或 部 分 人 浏览 。 
本 实例 讲解 的 主要 内 容 并 不 是 如 何 实现 浏览 这 一 功能 , 而 是 对 浏览 页 面 的 <div> 布 局 。 运 行 本 实例 , 效果 如 图 3.49 
所 示 。 


帖子 中 心 


四 PiD_ IE 有 i | 
Pb phP 典 亚 针 块 修订 版 ， 已 经 出 版 了 。 乔 
过 上 刻 广 大 读者 批评 指正 。 


图 3.49 论坛 帖子 的 浏览 页 面 


图 关键 技术 
本 实例 的 关键 点 是 利用 <div> 的 定位 技术 对 页 面 进行 合理 布局 ， 其 中 实现 定位 的 div 元 素 控制 的 代码 如 下 : 


.one{ 


background:url(../pic/bgjpg): 
} 

‘three{ 

margin-top:200px; 
margin-lefit:100px; 

} 

‘five{ 

margin-left:100px: 

和 


力 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 ， 连 接 数据 库 ， 完 成 数据 库 中 数据 的 分 页 输出 ， 代 码 如 下 : 


<div class="one"> 
<div class="two"> 


<?php 
$conn = mysql_connect("localhost", "root","111") or die ("Connect MySQI False"): // 连 接 数据 库 
mysql_select_db("db_database03",$conn) or die ("Connect db False"): 
mysql_query("SET NAMES UTF8"): 
Snum= 1 
Srs = mysql_query("select * from tb_demo01"); 
Smu = mysql_num rows($rs): 
ifisset(S_GET[page])){f 
Spage =$_GET[page]: 
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jelsef 
Spage = 1; 


} 
if($page < Smu){ /分 页 
> 


es 
<a href="index.php?page=<?php echo ($page+1):?>"> 下 一 页 </a> 
</div> 
<?php 
jelsef 
> 
<div class="three"> 
<a href="index.php?page=<?php echo ($page-1):?>"> 上 一 页 </a> 
<div> 
<?php 
} 
Spag = $page - 1; 
$sqlstr = "select * from tb demo01 limit $pag,1"; 
Srss = mysql query($sqlstr); 
Srey = mysql_fetch_array($rss); 
?> 
<div class="five"> 
<table width="500px" border="1" bordercolor="#FF0000" cellspacing="0"> // 数 据 输出 
<tr> 
<td width="70px"> 用 户 ID</td><td width: 
<t> 
<tr> 
<td><?php echo S$rey[id]?></td><td><?php echo Sreyltitle]?></td><td><?php echo Srey[content]?></td> 
<lt> 
<ltable> 
</div> 
<ldiv> 
(2) 编写 CSS 样式 ， 代 码 如 下 : 
body{ 
margin:0px; 


"150px"> 标 题 </td><td> 内 容 </td> 


.one{ 
margin:auto; 

width:700px; 

height'S00px: 
background:url(./pic/bgjpg); 


td{ 
font-family:" 楷 体 _GB2312"; 
font-size:15px: 
color:#0099FF; 

} 

fivef 

margin-left:100px; 

} 


a 
{ 

font-family:" 楷 体 _GB2312"; 
border-bottom:0: 
border-left:2px #FF0000 solid; 
border-right:2px #FF0000 solid: 
border-top:2px #FF0000 solid: 

} 

alink{ 

text-decoration:none; 
color:#000000; 

} 
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arvisited{ 
text-decoration:none; 


心 法 领悟 193: 相对 路 径 与 绝对 路 径 。 

相对 路 径 与 绝对 路 径 是 在 日 常 程序 开发 过 程 中 经 常用 到 的 两 个 概念 。 相 对 路 径 是 指 以 当前 文件 为 参照 物 ， 
其 他 文件 的 位 置 ， 绝 对 路 径 指 文件 的 绝对 位 置 ， 即 文件 在 本 机 中 的 绝对 位 置 。 以 本 实例 为 例 ， 以 background: 
ul(../pic/bg.jpg); 引 入 背景 图 片 ， 此 路 径 为 相对 路 径 。 


CR 

后 台 管理 页 面 高 级 | 
4 起 味 指数 : 贾 页 页 页 | 
国 实例 说 明 


所 有 的 Web 开发 者 几乎 都 是 从 最 简单 的 HTML 语言 开始 学 起 ， 所 以 较 <div> 标 签 来 说 ， 程 序 员 更 喜欢 用 
<table> 标 签 来 完成 网 页 框架 的 布局 。 但 是 从 网 站 优化 的 角度 来 说 ，<div> 标 签 确实 优 于 <table> 标 签 。 本 实例 通过 
设计 后 台 管 理 页 面 ， 着 重 阐 述 如 何 使 用 <div> 布 局 。 运 行 本 实例 ， 效 果 如 图 3.50 所 示 。 


FIWRINTY 


落后 台 管 理 系统 We wi Wi Tf : 天 是 : 20loss 有 oz 日 有 
加 你 当前 的 位 置 : [业务 中 心 ]-[ 交 的 6 件 ] [TY 
厂 序号 接收 号 码 时 间 邮件 地 址 内 容 基本 换 作 
看 企业 中 心 ol sense 二 二 0 信 编 辑 。 着 出 除 
日 基地 业务 Foz enue esos we a 信 的 和 。 其 册 除 
外 配置 环境 口 信访 可 。 其 删除 
下 密 保 修改 口 个 编程 。 办 天 除 
口 2 坊 旨 其 册 除 
| 口 过 坑 各 等 出 除 
日 系统 维护 口 Fin Wh 
入 口 安全 中 心 后 沁 编 辑 。 其 删 除 
日 措施 手段 rc 少 沪 本 其 册 除 
日 设置 窑 保 0 他 的 本 。 共 册 除 
而 重新 申请 共有 120 条 记录 ,当前 第 1/10 页 首页 3 让 二 页] 不 二 页 ]|[ 怖 页 转 到 第 | | 页 [地 转 | 


3.50 ”后 台 管理 页 面 


力 关键 技术 


本 实例 利用 <div> 标 签 进 行 网 页 布局 ， 并 利用 CSS 定义 宽 、 高 等 属性 。 实 现 定位 的 核心 代码 如 下 : 
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height:600px: 


} 
b{ 


margin:0px; 

width:1023px; 

height:80px: 
background:url(../pic/top.jpg); 
} 

<{ 

margin:0px; 

width:16Spx; 

height:310px: 
position:absolute; 
background:url(../pic/leftjpg); 


background:url(../pic/right.JPG); 
float:right: 
} 


<{ 
background:url(../pic/down.JPG); 
width:1023px: 

height:10px; 

} 


图 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 ， 代 码 如 下 : 
<div class="a"> 
<div class="b"></div> 
<div class="e"> </div> 
<div class="d"> 
</div> 
<div class="e"></div> 
</div> 


(2) 编写 CSS 样式， 代码 见 关键 技术 。 
国 秘笈 心 法 
心 法 领悟 194: CSS 样式 中 ， 如 何 使 文本 或 标签 居中 显示 。 


在 <div> 标 签 定位 中 ， 如 果 想 使 <div> 标 签 内 部 的 内 容 或 标签 居中 显示 ， 可 以 使 用 CSS 中 的 text-align 属性 
实现 。 
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力 实例 说 明 


在 设计 网 页 的 过 程 中 ,能 否 控制 好 各 个 模块 的 位 置 是 很 重要 的 ， 而 控制 这 些 模块 的 标签 中 <div> 是 最 常用 的 
标记 。 利 用 <div> 标 签 再 加 上 CSS 对 其 进行 样式 控制 ， 可 以 实现 很 多 效果 。 下 面 讲解 <div> 标 签 的 使 用 特点 和 应 
用 技巧 。 运 行 本 实例 ， 效 果 如 图 3.51 所 示 。 
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图 3.51 利用 <div> 标 签 布局 


图 关键 技术 


本 实例 用 到 的 属性 包括 margin、width、height、float、clear， 具 体 说 明 如 下 : 

(1) margin: 控制 模块 与 外 边 距 的 距离 。 其 中 ， 如 果 只 定义 1 个 参数 ， 表 示 到 四 边 的 边 距 ， 定 义 3 个 参数 
表示 到 上 、 左 / 右 、 下 的 边 距 ， 定 义 2 个 参数 表示 到 上 /下 和 左 / 右 的 边 距 。 

(2) width: 定义 <div> 模 块 的 宽度 。 

(3) hight， 定义 <div> 模 块 的 高 度 。 

(4) float: 指定 <div> 对 象 模块 如 何 浮 动 ， 其 中 包括 3 个 参数 ， 分 别 是 left、right、none， 表 示 向 左 浮动 、 
向 右 浮 动 、 不 浮动 。 

(5) clear: 指定 是 否 允许 浮动 对 象 ， 其 中 包括 4 个 参数 ， 即 left、right、both、none， 分 别 表示 清除 左 侧 浮 
动 、 清 除 右 侧 浮动 、 清 除 两 侧 浮动 、 不 清除 浮动 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 定 位 技术 设计 网 页 结构 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f"></div> 
<div class="j"></div> 
</div> 
<div class="c"></div> 
<div class="d"> 
<div class="g"></div> 
<div class="h"></div> 
<div class="i"></div> 
<div> 
<div class="e"> 
<div class="k"></div> 
<div> 
<div> 
(2) 编写 CSS 样式 ， 将 <div> 模 块 定位 到 指定 位 置 并 添加 背景 颜色 ， 代 码 如 下 : 
body{ 


margin:0px: 
background:#CCCCCC: 
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} 

af 
margin:auto; 
width:700px; 
height:600px: 
background:#FFFFFF:; 
} 

bf 
margin:Spx; 
width:700px; 
height:SOpx:; 


background:#CCCCCC: 


} 

£{ 

margin:2px; 
width:200px; 
height:75px; 
float:left; 
background:#FF0000; 


height:75px:; 
float:right: 

clear:left; 
background:#0099FF; 
} 

ef 

margin:Spx; 
width:714px; 
height:30px; 
background:#666666; 


height:400px: 
background:#6699FF; 


height:400px: 
background:#00FF00; 
float:left: 

} 

ht{ 

margin:Spx; 
width:300px; 
height:400px; 
background:#990000; 
float:left: 

} 

这 

margin:Spx: 
width:275px; 
height:400px; 
background:#99FF33; 
float:right: 

} 

ef 

margin:Spx: 
width:714px; 
height100px: 
background:#CC66CC: 
} 

kf{ 

margin:Spx auto Spx: 
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width:200px; 
height:90px; 
background:#FFFFO00; 
} 


国 秘笈 心 法 
心 法 领悟 195: clear 属性 的 具体 应 用 。 


假设 外 部 <div> 标 签 定义 宽度 为 400 个 像素 ， 内 部 定义 的 两 个 <div> 标 签 的 总 宽度 为 450 个 像素 ， 如 果 内 部 
右 侧 的 <div> 标 签 不 能 清除 左 侧 的 浮动 的 话 ， 将 会 产生 换行 效果 。 


图 实例 说 明 


在 比较 小 的 博客 中 ， 网 页 一 般 分 为 上 、 中 、 下 3 个 部 分 ， 中 间 部 分 又 分 左 、 右 两 个 部 分 。 如 果 利 用 HTML 
的 <table> 标 签 实现 ， 则 需要 多 个 <table> 标 签 进行 嵌 套 ， 但 是 如 果 利用 <div> 标 签 ， 结 构 就 比较 明朗 了 。 下 面 来 实 
现 这 一 实例 ， 运 行 结 果 如 图 3.52 所 示 。 


pg 
高 级 | 
起 听 指 数 宙 页 寅 od 


图 3.52 页 面 布局 之 2 列 左 罕 右 宽 高 度 自 适应 


图 关键 技术 


本 实例 的 关键 点 是 如 何 实现 <div> 模 块 的 高 度 自 适应 。 其 实 实现 这 一 功能 很 简单 ， 只 需要 定义 height 属性 为 
auto 即 可 ， 代 码 如 下 : 


height:auto: 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 并 输出 提示 文字 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 


<div class="f'></div> 
<div class="j"></div> 


<div> 
<div class="c"></div> 
<div class="d"> 

<div class="g"> 
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明日 科技 <br>PHP 开发 实录 <br> 典 型 模块 大 全 <br> 


<div> 
<div class="h"> 


明 <br> 日 <br> 科 <br> 技 <br> 编 <br> 程 <br> 词 <br> 典 <br> 修 <br> 订 <br> 版 <br> 马 <br> 上 <br> 就 <br> 要 <br> 上 <br> 市 <br> 啦 1! 


</div> 
</div> 
<div class="e"> 


<div class="k"></div> 


<div> 
<div> 


(2) 编写 CSS 样式 ， 定 义 <div> 模 块 的 宽度 和 高 度 ， 并 为 输出 的 文字 定义 样式 ， 代 码 如 下 : 


body{ 
margin:0px: 
background:#CCCCCC: 


width:700px; 
height:SOpx; 
background:#CCCCCC; 


width:200px; 
height:75px: 
float:left; 
background:#FF0000; 


width:500px; 
height:75px: 
float:right: 
clear:left; 


height:400px: 
background:#6699FF: 
} 

‘2{ 

margin:Spx; 
width:200px; 
heightauto: 
background:#00FFO0; 
float:left: 

font-family:" 楷 体 _GB2312":; 
font-size:16px: 

} 
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hf{ 
margin:5px: 
width:485px: 
height:auto; 
background:#990000; 
float:right: 

clear:left: 


font-family:" 楷 体 _GB2312"; 


color:#FFFFFF: 
font-size:18px; 


height100px: 
background:#CC66CC; 
} 

k{ 

margin:Spx auto Spx; 
width:200px; 
height:90px: 
background:#FFFF00; 
} 


国 秘笈 心 法 
心 法 领悟 196: 什么 是 高 度 自 适 应 。 


所 谓 的 高 度 自 适应 是 指 根据 文本 内 容 的 多 少 自动 调整 相应 的 高 度 ， 这 样 设置 的 优点 是 可 以 完全 不 浪费 网 页 
空间 ， 而 且 使 页 面 效果 饱满 丰富 。 高 度 自 适应 在 网 页 设计 中 被 广泛 使 用 。 
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: 
趣味 指数 : 克 友 友 友 | 


实例 196 已 经 讲解 了 页 面 布局 中 左 窗 右 宽 的 情况 ， 本 实例 介绍 2 列 固定 宽度 的 实现 方法 。 运 行 本 实例 ， 效 
果 如 图 3.53 所 示 。 


RE OR TE 
司 


图 3.53 页 面 布局 之 2 列 固 定 宽度 + 头 部 + 导航 + 尾部 
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图 关键 技术 
本 实例 设 定 


‘2{ 

margin:Spx; 
width:340px; 
height:300px:; 
background:#00FF00; 
float:left: 

} 

h{ 

margin:Spx; 
width:340px; 
height:300px: 
background:#990000; 
float:right: 

clear:left; 

} 


图 设计 过 程 


区 


定 宽度 的 方法 是 定义 width 属性 为 固定 值 ， 代 码 如 下 : 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 并 输出 提示 文字 ， 代 码 如 下 ; 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="e"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"><h1> 长 春 市 明日 科技 有 限 公司 </h1></div> 
<div class="h"> 明 日 科技 图 书 ， 新 书 上 市 啦 </div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
</div> 


(2) 编写 CSS 样式 ， 定 义 <div> 相 关 属性 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 


height:500px: 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px; 
color:-#FFFFFF; 


width:200px: 
height:75px: 
float:left: 
background:#FF0000: 
} 

EL 

margin:2px: 
width:500px; 
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height75px: 


国 秘笈 心 法 
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心 法 领悟 197: float 属性 的 使 用 方法 。 


在 定义 身体 部 分 时 ， 如 果 身 体 部 分 只 有 两 部 分 ， 可 以 利用 float 属性 ， 一 侧 向 左 浮动 ， 一 侧 向 右 浮动 ， 但 是 
如 果 身 体 部 分 分 为 3 个 部 分 ， 那 么 定义 为 以 左面 起 ， 前 两 个 向 左 浮动 ， 最 后 一 个 向 右 浮动 为 好 。 


人 
趣味 指数 : 但 食 食 食 


实例 198 


国 实例 说 明 


实例 196 和 实例 197 都 是 以 中 间 为 两 个 模块 进行 布局 。 本 实例 讲解 中 间 为 3 个 模块 的 实例 ， 并 且 实 现 左 右 


侧 固 定 ， 中 间 自 适应 居中 显示 ， 运 行 效果 如 图 3.54 所 示 。 
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图 3.54 页 面 布局 之 3 列 左右 侧 固 定 中 间 自 适应 居中 


图 关键 技术 


本 实例 的 关键 点 是 如 何 实现 中 间 模 块 自 适应 居中 。 答 案 很 简单 ， 将 模块 的 margin 属性 设置 为 上 下 方向 与 边 
距 为 5 个 像素 ， 左 右 方向 为 auto 自动 设置 即 可 ， 核 心 代码 如 下 : 
h{ 


margin:5px auto; 
width:38Spx; 
height:auto:; 
background:#FFCCFF; 
float:left; 
text-align:center; 


} 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 进行 网 页 定位 布局 ， 其 中 包括 头 部 、 颈 部 、 身 体 部 分 和 脚 部 ， 代 码 


如 下 : 
<div class="a"> 
<div class="b"> 
<div class="f'> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<h1> 长 春 市 明日 科技 有 限 公 司 </h1> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
<div class="i"> 
敬 请 期 待 实战 范例 宝典 
</div> 
<ldiv> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 
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(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 宽 和 高 ， 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 
body{ 

margin:0px: 
background:#CCCCCC: 

} 

af 

margin:auto; 
width:700px; 
height:500px: 
background:#FFFFFF:; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px: 
color-#FFFFFF; 


width:700px; 
height:80px: 
background:#CCCCCC; 
} 

ff 

margin:2px; 
width:200px; 
height:75px; 
float:left; 
background:#FF0000; 
i{ 

margin:2px; 
width:S00px; 
height:75px: 
float:right; 

clear:left; 
background:#0099FF; 


height:300px: 
background:#6699FF: 


margin:Spx auto: 
width:385px: 
height:auto: 
background:#FFCCFF: 
float:left; 
text-align:center; 

} 

这 

margin:Spx: 
width:150px: 
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height:300px: 


心 法 领悟 198: 使 数据 居中 显示 的 方法 。 
CSS 样式 中 有 一 个 text-align 属性 ， 相 当 于 使 用 <table> 标 签 中 的 center 属性 ， 可 以 使 页 面 数据 居中 显示 。 


gas 
图 实例 说 明 


灵活 地 控制 页 面 中 <div> 标 签 的 宽度 和 高 度 是 使 用 <div> 标 签 的 核心 。 本 实例 实现 身体 部 分 2 列 右 侧 固 定 左 
侧 自 适应 宽度 ， 未 知 高 度 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 如 图 3.55 所 示 。 


ER 
长 春 市 明日 笠 技 有 有限 侠 司 


3.55 页 面 布局 之 2 列 右 侧 固 定 左 侧 自 适应 宽度 


力 关键 技术 
本 实例 的 关键 点 是 实现 身体 部 分 左 侧 自 适应 宽度 且 未 知 高 度 。 实 现 思想 是 设置 width、height 属性 ， 代 码 
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height:auto; 
background:#00FF00; 
float:left; 

} 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f'> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="e"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公司 <hl> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
</div> 
(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 
margin:0px: 
background:#CCCCCC; 
} 
a{f 
margin:auto; 
width: 700px; 


18px: 
color:#FFFFFF: 


height:80px: 
background:#CCCCCC: 


background:#FF0000: 
} 

i{ 

margin:2px: 
width:500px: 
height:75px: 
float:right: 

clear:left: 
background:#0099FF: 
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background:#00FF00: 


text-align:center; 

} 

ef 

margin:Spx; 
width:714px:; 
height:100px; 
background:#CC66CC: 


图 秘笈 心 法 


心 法 领悟 199: 关键 字 auto 的 使 用 。 
在 <div> 标 签 中 ， 如 果 不 知 道 该 标签 的 具体 宽度 和 长 度 或 者 与 四 边 的 距离 ， 可 以 将 这 些 属性 设置 为 auto。 这 
样 可 以 让 <div> 标 签 的 长 度 和 宽度 自动 调节 。 


固定 右 侧 自 适应 宽度 + 底 平 齐 ) ”高 级 | 


实例 200 趣味 指数 : 让 让 俱全 | 


力 实例 说 明 


利用 <div> 设 计 页 面 时 ， 有 很 多 很 小 的 技巧 ， 灵 活 地 掌握 这 些 技巧 可 以 使 用 户 对 页 面 设计 葡 然 开朗 。 本 实例 
主要 实现 身体 部 分 的 2 列 左 侧 固 定 右 侧 自 适 应 宽度 ， 未 知 高 度 且 底部 平 齐 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 运 行 
效果 如 图 3.56 所 示 。 
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长 琳 市 明日 科技 态 除 
公司 


图 3.56 页 面 布局 之 2 列 左 固定 右 自 适 宽度 + 底 平 齐 


图 关键 技术 


本 实例 的 关键 点 是 实现 身体 部 分 右 侧 自 适应 宽度 且 未 知 高 度 ， 底 部 平 齐 。 实 现 思想 是 设置 width、height、 
margin 属性 ， 代 码 如 下 : 
ht{ 


margin:5px Spx Opx Spx; 
width:auto: 

heightauto: 
background:#FFCCFF: 
float:right: 


text-align:center; 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f"> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公司 <Ihl> 
</div> 
<div class="h"> 
明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <br> 上 <br> 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br> 注 <br> 
<ldiv> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 


(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 


margin:Opx: 
background:#CCCCCC: 
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af 
margin:auto; 

width:700px: 
height:500px: 
background:#FFFFFF: 
font-family:" 经 典 趣 体 简 "; 
font-size:18px: 
color#FFFFFF; 


width:700px; 
height:80px; 
background:#CCCCCC: 
} 

f{ 

margin:2px; 
width:200px; 
height:75px: 

float:left; 
background:#FF0000; 


height:75px:; 
float:right: 
clear:left; 
background:#0099FF; 
} 


width:714px; 
height:30px: 
background:#666666; 


width:714px; 
height:300px; 
background:#6699FF; 
} 


height:300px; 
background:#00FFO00; 
float:left: 

} 

hf 

margin:Spx Spx Opx Spx: 
width:auto: 
height:auto: 
background:#FFCCFF:; 
float:right: 
text-align:center; 


width:714px: 
height:100px: 
background:#CC66CC; 
} 

kf{ 

margin:Spx auto Spx: 
width:200px: 
height:90px: 
background:#FFFFO0; 
color:-#000000; 

} 


2S1 
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图 秘笈 心 法 
心 法 领悟 200， 属 性 margin 与 底部 平 齐 。 


margin 属性 在 实例 185 中 已 经 讲解 过 ， 所 谓 的 底部 平 齐 就 是 指 下 边 距 为 0 像素 ， 所 以 只 要 设置 当前 模块 的 
下 边 距 属性 值 为 0 像素 即 可 。 


定 左 侧 自 适应 宽度 + 底 平 齐 ) 高级 
趣味 指教 : 依依 依依 


实例 201 


力 实例 说 明 
本 实例 是 实例 200 的 对 照 ， 意 在 使 读者 对 <div> 定 位 技术 有 深入 的 了 解 ， 运 行 结果 如 图 3.57 所 示 。 


长 
束 
市 
明 
9 
简 
接 
有 
限 


3.57 页面 布局 之 2 列 右 固定 左 自 适 宽度 + 底 平 齐 


力 关键 技术 
本 实例 的 方法 与 实例 200 相同 ， 这 里 不 再 次 述 。 
力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建 立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公 司 <hl> 
<ldiv> 
<div class="h"> 
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明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <be> 上 <be> 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br> 注 <br> 


(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 

margin:0px; 
background:#CCCCCC; 

} 

af 

margin:auto; 
width:700px; 
height:500px: 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px; 
color:#FFFFFF; 


float:left: 
background:#FF0000; 


height:75px; 
float:right:; 

clear:left; 
background:#0099FF; 


height:30px: 
background:#666666; 
} 

df 

margin:Spx; 
width:714px; 
height:300px: 
background:#6699FF; 
} 

‘g{ 

margin:Spx Spx Opx Spx; 
width:auto: 
height:auto; 
background:#00FF00: 
float:left; 


height:300px: 
background:#FFCCFF: 
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图 秘笈 心 ; 


心 法 领悟 201: padding 补丁 边 距 。 
本 实例 中 ， 因 为 设置 底部 平 齐 ， 所 以 右 侧 固定 宽度 的 模块 就 可 能 与 底 边 距 不 是 5 个 像素 的 距离 ， 为 了 整体 
的 美感 效果 ， 可 以 为 右 侧 模块 设置 padding 补丁 边 距 ， 设 置 好 合适 距离 后 ， 显 示 效 果 如 图 3.57 所 示 。 


3.6 弹出 窗口 


弹出 窗口 经 常 在 网 站 中 使 用 ， 如 弹出 式 广告 或 网 站 公告 及 打开 居中 显示 详细 信息 的 新 窗口 等 。 所 以 掌握 设 
计 弹 出 窗口 的 技术 ， 也 许 会 给 设计 的 网 站 带 来 额外 的 效益 。 


实例 202 趣味 指数 : 容 让 让 全 


力 实例 说 明 


JavaScript 这 门 脚本 语言 的 功能 很 强大 ,尤其 是 在 网 页 特效 的 处 理 上 更 是 有 其 独到 之 处 。 本 实例 将 讲述 的 是 
通过 JavaScript 代码 控制 ， 弹 出 指定 尺寸 的 无 边框 窗口 ， 如 图 3.58 所 示 。 


文件 中 护驾) 查看 WW ”| 圳 
地 址 四 ) | 估 http /| 加 甘 到 | 外接 


单 击 此 区 域 
弹出 窗口 


图 3.58 单 击 跳 转 图 
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图 关键 技术 
本 实例 主要 是 利用 JavaScript 代码 ， 控 制 弹 出 窗口 的 尺寸 ， 核 心 代码 如 下 : 


selfresizeTo(250.180): 

width=screen width: 

height=screen height: 
self.moveTo((width-240)/2,(height-139)/2): 


图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 定位 技术 建立 网 页 架构 ， 引 入 CSS 文件 ， 当 单 击 图 标 按钮 时 发 生 跳 转 ， 
代码 如 下 : 
<div class="a"><img sre="pic/bgjpg" border="0" usemap="#Map" /> 
<map name="Map" id="Map"><area shape="rect" coords="469.298.541.382" href="in.php" /></map> 


<ldiv> 
(2) 创建 脚本 文件 ， 命 名 为 iphp， 此 文件 执行 跳 转 后 的 代码 。 另 外 ， 在 此 文件 中 建立 form 表单 ， 代 码 
如 下 : 
<div class="c"> 
用 户 名 : <input type="text" name="text"><br> 
密 &nbsp:&nbsp: 码 : <input type="password"><br> 
<input type="button" class="one" valuc="">&nbsp:&nbsp:<input type="button" class="two"value=""> 
</div> 
(3) 编写 JavaScript 脚本 ， 定 义 网 页 窗口 的 尺寸 并 定义 当 鼠 标 覆 盖 和 移 开 文本 框 时 产生 的 变色 效果 ， 代 码 
如 下 : 
S$(document) ready(function(){ 
self.resizeTo(250,180); // 定 义 窗口 的 宽 和 高 
width=screen.width; 
height=screen.height; 
sclfmoveTo((width-240)/2.(height-139)/2): 
$("input:eq(0)").mouseover(functionO{ // 当 鼠标 覆盖 时 
$("input:eq(0)").css("background","#FFCCFF");: 
S$("input:eq(0)").mouseout(functionO{ // 当 鼠标 移 开 时 
S$("input:eq(0)").css("background","#FFFFFF"): 


jy 
S("inputeq(1D))mouseovertfunction0{ 
S$("input:eq(1)").css("background","#FFCCFF"): 
S$("input:eq(1)").mouseout(functionO{ 
S("input:eq(1)").css("background","#FFFFFF"): 
ba 
D; 
图 秘笈 心 法 
心 法 领悟 202: HTML 的 <map> 标 签 。 
如 果 用 户 使 用 的 编程 工具 是 Dreamweaver， 那 么 对 于 <map> 标 签 应 该 并 不 陌生 ， 此 标签 的 主要 作用 是 当 鼠 
标 单 击 指定 区 域 时 ， 网 页 发 生 跳 转 。 


的 

高 级 | 

实例 203 起 味 指教 : 相机 页 宣 | 
实例 说 明 


通常 用 户 在 使 用 正 浏览 器 浏览 网 页 时 ， 浏 览 器 窗口 包括 标题 栏 、 菜 单 栏 和 状态 栏 等 固定 内 容 。 虽 然 菜单 栏 
和 状态 栏 可 以 通过 设置 而 隐藏 ， 但 是 标题 栏 却 不 能 隐藏 ， 即 使 将 网 页 全 屏 显示 也 不 能 将 其 去 除 。 有 时 为 了 网 站 
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的 整体 效果 考虑 ， 需 要 将 网 页 设置 为 全 屏 显 示 。 例 如 ， 在 明日 网 络 宽带 影院 网 站 中 ， 为 了 给 用 户 以 更 真实 的 感 
觉 ， 就 可 以 将 整个 网 站 的 主页 面 设置 为 全 屏 显示 模式 ， 如 图 3.59 所 示 ， 从 图 中 可 以 看 出 该 页 面 中 还 设计 了 “ 退 
出 ” 超 链接 ， 可 以 方便 浏览 者 随时 离开 影院 ， 这 也 是 设计 全 屏 显 示 时 需要 注意 的 问题 ， 否 则 浏览 者 会 因 找 不 到 
出 口 而 烦恼 。 


明日 网 络 宽带 影院 


图 3.59 全 屏 显 示 


图 关键 技术 


本 实例 主要 通过 window 对 象 的 open0 方 法 ， 并 借助 一 个 中 转 页 实现 ， 当 中 转 页 运行 时 调用 open0 方 法 打 
开 一 个 全 屏 显 示 的 窗口 (使 用 window 对 象 的 open0 方 法 中 的 参数 fullscreen=1 实现 ) ， 并 关闭 打开 中 转 页 的 
窗口 。 


图 设计 过 程 
新 建 一 个 空 的 PHP 页 面 (页 面 中 可 以 没有 任何 页 面 布局 元 素 或 内 容 ) ， 命 名 为 index.php。 该 页 面 只 是 起 到 


一 个 页 面 跳 转 的 作用 ， 主 要 应 用 JavaScript 脚本 自 定义 一 个 MM_c0 函 数 ， 并 应 用 window 对 象 的 open() 方 法 打 
开 一 个 新 的 formal.htm 页 ， 设 置 参数 fullscreen=1， 从 而 实现 打开 窗口 的 全 屏 显 示 ， 代 码 如 下 : 


<object type="application/x-oleobject" id=closes classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11"> 


closes Click0: 
window.open("formal htm","", "fullsereen=1"): 


<lscript> 
国 秘笈 心 法 
心 法 领悟 203: 全 屏 显 示 的 主要 应 用 。 


用 户 在 浏览 类 似 于 土豆 、 优 酷 等 网 站 的 视频 时 ， 经 常会 看 到 播放 器 的 下 方 存在 一 个 全 屏 显 示 的 按钮 ， 其 实 
现 方法 与 本 实例 大 同 小 异 ， 只 是 使 用 的 控制 方法 不 同 而 已 。 
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高 级 | 
实例 204 趣味 指数 ; 容 丰 丰 宙 | 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 用 户 经 常 要 求 在 客户 端 应 用 自 定义 颜色 来 改变 某 些 信息 或 控件 等 的 颜色 值 ， 如 留言 本 
中 的 文字 颜色 、 控 件 背 景色 等 ， 通 过 在 网 页 中 加 入 一 个 网 页 拾 色 器 即 可 实现 。 运 行 本 实例 ， 将 在 页 面 中 显示 如 
图 3.60 所 示 的 网 页 拾 色 器 ， 当 用 户 单 击 颜色 块 时 ， 就 会 弹出 一 个 提示 框 ， 提 示 其 所 选 的 颜色 值 是 多 少 ， 通 过 选 
择 的 颜色 值 来 改变 网 页 的 背景 色 。 


图 3.60 网 页 拾 色 器 


力 关键 技术 


本 实例 的 关键 点 是 在 实现 网 页 拾 色 器 时 ， 应 用 JavaScript 的 数组 。 创 建 数组 有 以 下 3 种 方法 : 
(1) 无 参数 调用 ， 语 法 格式 如 下 : 
varh=new Amay0: 
(2) 指定 数组 前 n 个 元 素 的 值 ， 语 法 格式 如 下 : 
var h = new Array(arglist): 
其 中 参数 arglist 是 一 个 用 逗号 隔 开 的 值 表 ， 这 些 值 用 于 给 variant 所 包含 的 数组 的 各 元 素 赋值 。 如 果 不 提供 
参数 ， 则 创建 一 个 长 度 为 0 的 数组 。 
(3) 指定 数组 的 元 素 个 数 ， 语 法 格式 如 下 : 
var h =new Amay(n); 
其 中 参数 n 是 指定 数组 的 长 度 。 由 于 在 JavaScript 中 ， 数 组 的 第 1 个 元 素 的 下 标 值 为 0， 所 以 n 的 值 为 数组 
的 最 大 下 标 值 加 1。 


图 设计 过 程 
(1) 创建 需要 调用 网 页 拾 色 器 的 页 面 ， 在 该 页 面 中 添加 一 个 文本 框 ， 将 文本 框 设 置 为 只 读 ， 同 时 将 文本 框 
的 背景 色 设置 为 黑色 ， 并 在 该 文本 框 的 onClick 事件 中 调用 自 定义 的 JavaScript 函数 colorpick0， 代 码 如 下 : 


<input name="eolor' type="text" id="color" size="3" readonly="yes" style="background-color#CCFF00" onClick="colorpick(this):"> 


(2) 编写 自 定义 的 JavaScript 函数 colorpick0， 用 于 打开 网 页 对 话 框 调 用 网 页 拾 色 器 ， 并 用 网 页 拾 色 器 的 


q 
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返回 值 设 置 文本 框 的 背景 色 和 网 页 的 背景 色 ， 代 码 如 下 : 
<script language="javascript"> 
function colorpick(field){ 
var rtn = window.showModalDialog("color.php"."™"."dialog Width:225px:dialogHeight:170px:status:no:help:no:scrolling=no:scrollbars=no"); 
if(rtn!=null) 
document.body.style.background=rtn: 
ficld.style.background=rtn: 
retum; 
} 


<lscript> 


(3) 制作 网 页 拾 色 器 页 面 color.php， 关 键 代码 如 下 : 


<script language="JavaScript"> 


function action(RGB) { 
parent.window.retumValue="#"+RGB:; 
window.closeO: 


} 

function Meell(R. G. B) { 
document.write('<td bgcolor="# +R+ G+B+">); 
document write(<a href="#" onClick="action(\" + (R + G+ B) + \)">); 
document write( <img border=0 height=12 width=12 \)" alt-\#+R+G+B+\>"); 
document.write('</a>"); 
document.write('</td>"); 


} 
function Mtr(R, B) { 
document.write('<tr>"): 
for (vari=0;i<6;++i) { 
Mcell(R. hfi], B): 
} 


document. write('</tr>") 


} 
function Mtable(B) { 
document. wri 


document. write('</table>"); 


} 
function Mcube() { 
document.write('<table cellpadding=0 cellspacing=0 border=0><tr>"); // 
for (vari=0:1<6: ++i) { 
if(i%3=—0){ 
document.write('<tr>"); 


} 
document.write('<td bgcolor="#FFFFFF">"): 
Mtable(h[i]) 
document.write('</td>"); 
} 
if(i%3==0){ 
document.write('</tr>"); 
} 
document.write('</tr></table>"): 
} 
Meube0 
</script> 


力 秘笈 心 法 


心 法 领悟 204: 浅 谈 variant 变量 。 
本 实例 中 没有 作为 数组 声明 的 variant 也 可 以 表示 数组 。 除 了 长 度 固 定 的 字符 串 以 及 用 户 定义 类 型 之 外 ， 
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variant 变量 可 以 表示 任何 类 型 的 数组 。 尽管 一 个 包含 数组 的 variant 和 一 个 元 素 为 variant 类 型 的 数组 在 概念 上 有 
所 不 同 ， 但 对 数组 元 素 的 访问 方式 是 相同 的 。 


| 
高 级 | 
起 呆 林 才 ;二 wx 


力 实例 说 明 


目前 ， 日 期 型 数据 格式 有 多 种 ， 采 用 录入 方式 相对 来 说 比较 繁琐 ， 而 且 采 用 这 种 方式 也 不 利于 日 期 格式 的 
统一 ， 所 以 可 以 在 信息 录入 页 面 中 加 入 一 个 简单 的 日 期 选择 器 来 解决 上 述 问题 。 运 行 本 实例 ， 在 新 奥 家 电 连 锁 
后 台 管理 系统 的 销售 查询 页 面 中 ， 单 击 “ 售 货 日 期 ”文本 框 后 的 日 期 选择 按钮 ， 会 弹出 “日 期 选择 器 ”对 话 框 ， 
选择 售 货 日 期 的 起 始 日 期 后 ， 单 击 “ 确 定 ”按钮 ， 即 可 成 功 地 将 选择 的 日 期 添加 到 对 应 的 日 期 文本 框 中 ， 运 行 
结果 如 图 3.61 所 示 。 


Ny iit 


售 黄 期: ”从 轩 1065 到 i086 回 本 i 


本 日 期 选择 器 一 网 页 对 话机 区 


2oos 引 


图 3.61 日 期 选择 器 


图 关键 技术 


由 于 日 期 为 连续 的 数字 , 开发 网 页 时 将 这 些 信息 逐个 写 在 <option> 与 </option> 标 记 之 间 固然 可 行 , 但 这 样 会 
增加 程序 开发 时 间 ， 在 开发 本 实例 时 ， 笔 者 将 通过 PHP 的 循环 结构 显示 出 下 拉 列 表 框 中 的 连续 数据 ， 这 样 更 灵 
活 方便 ， 实 现 该 过 程 的 代码 如 下 : 


<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="addday()"></a></div></td> 
<td width="80"> 
‘<select name="n1"> 


<?php 
for($i=2005:$i<=2050:$i++){ 
2> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
> 
</select> 


年 <ltd> 
<td width="64"><select name="yl"> 


<?php 
for($i=1:$1<=12:$iH+){ 
?> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 


<php 
} 
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> 
</sclect> 
月 <itd> 
<td width="77"><select name="r1"> 
<?php 
for(Si=1:$i<=31:SitH{ 
?> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
sphp 
1 
?> 
</select> 
日 <td> 
<td width="16"><div align="center"><a href="#" onClick="subdayO"></a></div></td> 
<lt> 
</form> 


设计 过 程 
(1) 在 父 窗口 中 创建 函数 open_day_from0 和 open_day_ to0， 实 现 子 窗口 的 弹出 和 父 窗口 与 子 窗口 之 间 的 
信息 传递 ， 代 码 如 下 : 


<table width="250" height="25" border="0" align="center' cellpadding="0" cellspacing: 
<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="addday()"></a></div></td> 
<td width="80"> 
‘<select name="n1"> 
<?php 
for(Si=2005:$i<=2050:Sit+) { 


?> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
< 
?php 
} 


?> 
<lselect> 
年 <td> 
<td width=' 
<?php 
for($i=1;$i<=12;$i++) { 


?> 


"><select name="y1"> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
?> 
</select> 
月 <htd> 
<td width="77"><select name="r1"> 
<?php 
for(Si=1:$i<=31:$itH) { 
?> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
} 
> 
</select> 
HB</td> 
<td width="16"><div align="center"><a href="#" onClick="subdayO|"></a></div></td> 
<ltr> 
</form> 
</table> 
<table width="250" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<a> 
<td bgcolor="#826650"><div align="center"><input type="button" onClick="close_day0" class="buttoncss" value=" 确 定 "></div></td> 
<lt> 
</table> 
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(2) 单 击 “确定 ”按钮 ， 调 用 close_day() 函 数 实现 日 期 的 传 值 ， 代 码 如 下 : 
<scriptlanguage="javascript> 
fonction close_dayO{ 
window.returnValue=document form2.n1.value+"-"+document form? .yl.value+"-"+document form2.r1.value; 
window.close(); 
} 


Jscript> 
图 秘 稚 心 ; 


心 法 领悟 205: JavaScript 弹出 窗口 。 


实现 窗口 之 间 的 信息 传递 主要 通过 window 的 showModalDialog0 方 法 实现 ， 其 语法 格式 如 下 : 
window.showModalDialog(' 弹 出 窗口 地 址 "弹出 窗口 名 称 ', "弹出 窗口 所 具有 的 属性 ) 


窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 栏 、 状 态 栏 、 滚 动 条 等 一 些 特性 。 


实例 206 趣味 指数 ， 宙 本 女 页 ， 
图 实例 说 明 


为 了 方便 用 户 浏览 网 页 信息 ， 可 以 将 网 页 信息 以 全 屏 显 示 的 网 页 模式 展示 给 用 户 ， 这 样 一 来 可 以 方便 用 户 
浏览 到 网 页 的 全 部 信息 ; 二 来 可 以 保证 用 户 查看 后 能 及 时 将 其 关闭 。 运 行 本 实例 ， 在 明日 科技 编程 词典 网 站 中 
单 击 “购买 须知 ” 超 链接 后 ， 将 弹出 如 图 3.62 所 示 的 购买 须知 页 面 ， 该 页 面 就 是 通过 全 屏 显示 的 网 页 模式 对 话 
框 ， 用 户 只 有 关闭 该 页 面 后 ， 才 可 以 查看 网 站 的 其 他 内 容 。 


友 编程 间 典 系列 版 本 及 价格 克 
和 @ Visaal Basic 护 得 间 典 
软件 版 本 功能 享受 服务 价格 (元 ) 
标准 版 | [8 一 年 两 次 升级 128 
开发 版 详 二 功能 。 | 每 月 升级 ， 每 月 归 送 最 新 软件 ， 编 程 训 。 全 年 提供 30 个 项 目 尖 程序 的 有 限 服务 支持 5 
二 版 说 二 能 。 | 每 月 升级 ， 和 月 参 送 晤 新 软件 ， 婉 程 术 赛 全 年 提供 60 个 项 目 源 查 序 的 有 限 服务 支持 。 1996 
企业 版 | 详细 功能 每 月 升级 ,每 月 赔 送 最 新 软件 ,编程 锦 宫 。 提 供 一 年 全 程 技术 支持 服务 。 | 6998 
罗 Delphi 编 程 词典 
软件 版 本 功能 享受 服务 价格 (元 ) 
| 标 从 版 训 和 动能。 | 一 年 丙 次 逢 组 128 
开发 上 证 让 。 | 每 月 天 婚 ， 每 月 参 送 是 新 软件 ， 纺 各 坟 塞 。 全 年 提供 20 个 项 目 尖 程序 的 有 限 服务 支持。 加 
专业 版 证 能 。 | 每 月 和 领 ， 年 月 震 关 晤 新 软件 ， 扩 程 赛 。 全 年 提供 90 个 项 目 尖 程序 的 有 限 服务 支持 1996 
| 做 详 绍 动能。 | 每 月 升 讨 ， 每 月 区 送 最 新 软件 ， 护 各 坟 覃 。 提供 一 年 全 程 技术 支持 服务 。 B00 


3.62 ”弹出 全 屏 显示 的 网 页 模式 对 话 框 


图 关键 技术 


本 实例 主要 应 用 screen 对 象 的 width 、height 属性 和 window 对 象 的 showModalDialog0 方 法 实现 ， 
showModalDialog0 方 法 用 于 弹出 全 屏 显示 的 网 页 模式 对 话 框 ， 其 语法 格式 如 下 : 


variant = object.showModalDialog(sURL [. vArguments [. sFeatures]]) 

参数 说 明 : 

sURL: 指定 URL 文件 地 址 。 

vArguments: 用 于 向 网 页 对 话 框 传递 参数 。 传 递 参数 的 类 型 不 受 限 制 ， 对 于 字符 串 类 型 ， 最 大 为 4096 个 字 


za 


PHP 开发 实例 大 全 (基础 卷 ) 
符 ， 但 也 可 以 传递 对 象 ， 如 index.html。 
图 设计 过 程 
(1) 创建 提供 “购买 须知 ” 超 链接 的 页 面 ， 在 该 页 面 中 添加 空 的 超 链 接 ， 在 该 超 链接 的 onClick 事件 中 调 


用 自 定义 JavaScript 函数 opendialog0， 代 码 如 下 : 
有 ree onClick="opendialog0 吃 购买 须知 <ja> 


(2) 编写 自 定义 JavaScript 函数 opendialog0， 用 于 打开 全 屏 显 示 的 网 页 对 话 框 ， 代 码 如 下 : 
<script language 一 javascript > 


var height=screen.height: 

window.showModalDialog("notice.php","","dialogWidth="+width+"px:dialogHeight="+height+ "px:status=no:help=no:scrollbars=no") 
} 

</script> 


国 秘笈 心 法 
心 法 领悟 206: showModalDialog0 与 showModelessDialog0 的 区 别 是 什么 。 


二 者 的 区 别 在 于 showModalDialog0 打 开 的 网 页 对 话 框 为 模式 窗口 ， 置 于 父 窗 口上 ， 必 须 关 闭 才能 访问 父 窗 
口 ， 而 showModelessDialog0 打 开 的 对 话 框 是 无 模式 窗口 ， 打 开 后 不 必 关 闭 也 可 以 访问 父 窗口 或 其 他 窗口 。 


Ee es i i ee | 


图 实例 说 明 


通常 情况 下 ， 当 使 用 JavaScript 的 window.close() 语 句 关闭 IE 主 窗口 时 , 会 弹出 一 个 “您 查看 的 网 页 正在 试 
图 关闭 窗口 。 是 否 关 闭 此 窗口 ? ”的 询问 对 话 框 。 在 制作 网 络 应 用 程序 时 ， 这 种 情况 是 用 户 不 想 看 到 的 ， 那 么 
如 何 才能 屏蔽 该 对 话 框 呢 ? 本 实例 将 介绍 解决 该 问题 的 方法 。 运 行 本 实例 ， 效 果 如 图 3.63 所 示 ， 单 击 “ 关 闭 窗 
口 ” 超 链 接 后 ， 该 正 窗口 将 被 直接 关闭 。 


QQ 编 夸 司 典 


oer ane Midst e a ak hts sai 
全 术 过 和 在 你 开 发 的 记 用 ， 快 提 太 得 水 


每 个 函数 均 提供 了 大 量 示例 和 奥 


全 的 项 上 


人 遇 新 89 西数 应 用 1 《PIF 编程 词典 ) 软件 开发 版 以 上 
和 
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图 3.63 关闭 窗口 不 弹出 对 话 框 


力 关键 技术 


本 实例 主要 应 用 window 对 象 的 opener 属性 将 要 关闭 的 正 窗口 的 打开 窗口 设置 为 null, 然后 再 通过 window 
对 象 的 close( 方 法 将 该 窗口 关闭 ， 这 样 就 不 会 弹出 询问 对 话 框 。 


图 设计 过 程 
创建 ndex php 文件 ， 添 加 一 个 用 于 关闭 窗口 的 超 链接 ， 在 该 超 链接 的 onClick 事件 中 添加 控制 窗口 关闭 的 


第 3 章 Web 页 面 交 互 
代码 如 下 : 


<a href="#" onClick="window.opener=null:window.close0:"> 。 关闭 窗口 </a> 


心 法 领悟 207: 详解 opener。 
opener 是 一 个 可 读 可 写 的 属性 ， 对 一 个 window 对 象 返回 一 个 引用 ， 用 于 指定 打开 本 窗口 的 窗口 对 象 ， 语 


opener 属性 返回 的 是 一 个 窗口 对 象 ， 其 与 打开 该 窗口 的 父 窗口 相 联 系 ， 当 访问 子 窗口 的 opener 属性 时 ， 返 
回 的 是 父 窗口 。 通 过 该 属性 ， 可 以 使 用 父 窗口 对 象 中 的 方法 和 属性 。 


= spe 


趣味 指数 : 依依 颂 育 | 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 需 要 考虑 网 站 的 安全 性 ， 例 如 ， 设 置 允许 哪些 用 户 访问 是 一 项 非常 重要 的 技术 。 本 实 
例 在 页 面 中 设置 一 个 访问 权限 ， 判 断 用 户 是 否 可 以 访问 该 网 页 。 如 果 用 户 名 和 密码 不 正确 就 不 可 以 访问 ， 并 弹 
出 提示 对 话 框 重 定向 到 该 网 页 ， 运 行 结果 如 图 3.64 所 示 。 


留言 人 : 
Email : 
E| 
全 言 内 容 : A managEeAn 
习 
| | 


3.64 ”弹出 提示 对 话 框 并 重 定向 网 页 


图 关键 技术 


本 实例 主要 将 PHP 与 JavaScript 相 结合 , 通过 JavaScript 脚 本 来 弹出 对 话 框 信息 ,应 用 window 对 象 中 的 alert0 


方法 和 窗口 属性 location 实现 此 功能 ， 语 法 格式 如 下 : 
alert (弹出 对 话 框 的 内 容 ); 
window.location hre 全 :重新 定向 的 页 面 : 


参数 说 明 : 
alert0: 弹出 一 个 警告 对 话 框 。 


PHP 开发 实例 大 全 (基础 卷 ) 
location: 定位 区 ， 也 叫 地 址 栏 ， 是 可 以 输入 URL 的 浏览 器 文本 区 。 
力 设计 过 程 
弹出 提示 对 话 框 并 重 定向 网 页 文件 的 关键 代码 如 下 : 


<?php session start();?> 
<title> 弹 出 提示 对 话 框 并 重 定向 网 页 <ltle> 


php 

这 $gly 一 tue && Smima=—true){ 

这 Sljid 一 tmuejf 

$lid-$_GET[liid]; 

echo "这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 !":} 


?> 


<?php }else{ 
echo "<script>alert (这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 !); window location hre 人 admin php':</script>"; 
} 


国 秘笈 心 法 
心 法 领悟 208: 浅 谈 网 页 重 定向 。 
这 里 的 网 页 重 定向 与 PHP 判断 用 户 登 录 权限 页 相似 ， 都 是 网 页 的 一 种 跳 转 方法 。 


力 实例 说 明 


进入 网 站 后 ， 很 多 网 站 都 会 弹出 一 个 新 窗口 (如 广告 等 ) ， 多 数 窗口 需要 浏览 者 自行 关闭 。 为 了 方便 浏览 
者 对 页 面 中 信息 的 浏览 ， 本 实例 运用 一 种 新 的 方法 来 解决 弹出 窗口 关闭 这 一 问题 。 当 浏览 者 进入 某 网 站 进行 济 
览 时 ， 无 须 关 闭 弹 出 的 新 窗口 ， 在 页 面 运行 超过 一 定 的 时 间 之 后 ， 该 窗口 将 自动 关闭 ， 这 样 将 大 大 方便 浏览 者 
的 浏览 。 运 行 本 实例 ， 将 弹出 一 个 新 窗口 显示 广告 信息 ， 如 图 3.65 所 示 ， 该 广告 窗口 在 页 面 运行 5 秒 钟 后 自动 
关闭 。 


六 中 相 归 食 食 让 让 


图 3.65 自动 关闭 的 广告 窗口 


图 关键 技术 
本 实例 主要 应 用 window 对 象 的 setTimeout0 方 法 ， 实 现 延 迟 执行 某 一 操作 。window 对 象 的 setTimeout() 方 


法 的 语法 格式 如 下 : 
setTimeout(expression.secdelay[ .language]) 


pa 


辣 


第 3 章 Web 页 面 交互 


参数 说 明 : 

expression: 是 一 个 字符 串 ， 可 包含 任何 对 函数 、 方 法 或 者 单个 JavaScript 语句 的 调用 。 

secdelay: 指定 运行 间隔 的 时 间 ， 以 毫秒 为 单位 。 

language: 指定 语句 或 参数 expression 调用 的 函数 所 使 用 的 脚本 语言 。 如 果 完 全 使 用 JavaScript， 则 不 需 设 
置 该 参数 。 


力 设计 过 程 


(1) 通过 JavaScript 脚本 实现 打开 新 窗口 功能 ， 代 码 如 下 : 
‘<script language 一 " Hasan 
window.open("new.htm", "new", "height=135,width=180,top=10.1eft=20"); 
</script> 


(2) 通过 设置 window 对 象 的 setTimeout0 方 法 ， 实 现 弹出 新 窗口 的 自动 关闭 ， 代 码 如 下 : 
EE 


| | 秘笈 心 ; 


心 法 领悟 209: 秒 与 毫秒 。 
如 果 用 户 不 是 运动 员 ， 很 少 能 接触 到 毫秒 这 个 单位 ， 但 是 在 计算 机 领域 中 ， 毫 秒 是 经 常 被 用 到 的 。 秒 与 毫 
秒 的 换算 比例 是 1:1000， 也 就 是 说 1 秒 等 于 1000 毫秒 。 


实例 210 


高 级 : 
趣味 指数 : holoiodl 


力 实例 说 明 


在 论坛 、 博 客 等 注册 页 面 添加 头像 选择 功能 ， 可 以 增加 网 页 活力 。 运 行 本 实例 ， 首 先 单 击 图 3.66 中 的 “ 头 
像 选 择 ” 超 链接 ， 在 弹出 的 窗口 中 选择 自己 喜爱 的 头像 后 ， 弹 出 窗口 将 自动 关闭 ， 注 册页 面 中 的 头像 变 成 用 户 
所 选择 的 头像 。 


日 用 户 注册 
用 户 昵称 : 
注册 密码 : 
E-mail; *# 请 第 入 真实 的 E-mail 地 址 
真实 姓名 
职 业 : 天 司 。 
“a 息 
[| 
的 号 码 : 
联系 电话 : vv | 
ED 


3.66 ”选择 头像 


图 关键 技术 


本 实例 通过 调用 window 对 象 的 showModalDialog( 方 法 弹出 一 个 窗口 ， 当 用 户 单 击 某 个 头像 后 ， 将 该 头像 
对 应 的 数值 传递 给 父 窗 口 ， 父 窗口 通过 传递 过 来 的 数值 指定 用 户 所 选择 的 头像 。 
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四 设计 过 程 


(1) 首先 在 窗口 中 添加 “头像 选择 ” 超 链 接 ， 以 便 调用 select_face0 函 数 实现 窗口 的 弹出 功能 ， 代 码 如 下 : 
[<a href="#" onclick="select face0" class="a1"> 头 像 选择 </a>] 


(2) 利 用 JavaScript 编写 select face0O) 函 数 , 实现 头像 选择 窗口 的 弹出 以 及 返回 用 户 所 选择 头像 对 应 的 数值 ， 
代码 如 下 : 


<script language="javascript"> 
function select_faceO{ 
var somevalue; 
somevalue=window.showModalDialog("browse.php"." 请 选择 您 喜欢 的 人 物 头像", "dialogWidth='310px':dialogHeight='240px':status='no:help='no'; 
scrollbars='no™"); 
document form regist.user sre.sre="images/head/"+somevalue+".gif"; 
} 
<lscript> 
(3) 在 弹出 的 窗口 中 通过 selectface0 函 数 返回 用 户 所 选择 头像 对 应 的 数值 ， 代 码 如 下 : 
<script language="javascript"> 
function selectface(ICQ){ 
windowxretumValue=ICQ: 
window.close(); 


} 
</script> 
图 秘笈 心 法 


心 法 领悟 210: showModalDialog0 方 法 详解 。 
window.showModalDialog( 弹出 窗口 地 址 ' 弹出 窗口 名 称 ' ' 弹 出 窗口 所 具有 的 属性 ) 


窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 栏 、 状 态 栏 、 滚 动 条 等 一 些 特性 。 


实例 211 


实例 说 明 


网 络 不 仅 是 信息 的 海洋 ， 也 是 广告 的 海洋 。 除 了 普通 的 gif 和 flash 之 外 ， 浮 动 广告 也 是 时 下 网 上 较为 流行 
的 广告 形式 之 一 ， 当 拖 抱 浏览 器 的 滚动 条 时 ， 这 种 页 面 上 浮动 的 广告 ， 可 以 跟随 屏幕 一 起 移动 ， 这 种 效果 对 于 
广告 展示 有 相当 大 的 实用 价值 。 本 实例 将 制作 一 个 浮动 的 广告 窗口 ， 运 行 结果 如 图 3.67 所 示 。 


一 一 
图 书 调查 显示 结果 


工 。 您 经 党 购买 的 编程 基 图 书展 于 帮 一 夫 ? 


开发 手册 三 百 例 三 技巧 三 实例 入 锦 厂 教程 
称 全 用 下 面 时 入 近 各 语言 或 工具 ? 


Tw Tw Tw TJ Tym Tr 厂 XE 


了 您 晤 可 意 购 开 或 借 同 攻关 图 7 
厂 入 放 $3 厂 讲解 ! 实 订 。 厂 三 全 空间 厂 百 鲁 型 三 技巧 型 
E24 


图 3.67 浮动 的 广告 窗口 
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力 关键 技术 


本 实例 主要 应 用 DIV 层 制作 浮动 广告 ,然后 应 用 documentwrite() 方 法 输出 DIV 层 。documentwrite() 方 法 的 
语法 格式 如 下 : 

document.write(value,...) 

参数 说 明 : 

value: 要 添加 到 document 的 任意 一 个 JavaScript 值 。 如 果 该 值 不 是 字符 串 ， 那 么 在 被 添加 至 文档 之 前 ， 会 
被 转化 成 一 个 字符 串 。 

.…: 任意 多 个 〈0 个 或 多 个 ) 要 依次) 写 入 文档 的 值 。 


力 设计 过 程 
(1) 在 网 站 首页 引入 JavaScript 脚本 文件 ， 代 码 如 下 : 


<SCRIPT language=JavaScript sre="js/leftjs"></SCRIPT> 


(2) 运用 JavaScript 脚本 自 定义 函数 ， 控 制 浮动 广告 的 位 置 及 其 相关 属性 ， 代 码 如 下 : 
var adve=0.15 
var collection; 
function motion0 { 
this.items= []; 
this.addItem= function(id,x,y,content){ 
document write(<DIV id="+id+' style="Z-INDEX: 10; POSITION: absolute width:80px; 
+(typeof(x)=='string'?eval(x):x)+':top:'+(typeof(y)=—='string'?eval(y):y)+">"+content+"</DIV>"); 


Var newltem= {}; 
newltem.object= document.getElementById(id); 
newltem.x= x; 

newltem.y=y; 

this.items[this.items.length]= newItem: 


8 
this.play=function(){ 
collection=this.items 
setInterval('playO',10); 

} 
} 
function play0 { 
for(var i=0;i<collection.length:i++) { 
var followOb= collection[i].object: 
varfollowObj x =(typeof(collection[i].x)=='string'?eval(collection[i].x):collection[i].x); 
var followObj_y= (typeof(collection[i].y)=='string'?eval(collection[i].y):collection[i].y); 
if(followObj.offsetLeft!=(document.body.scrollLeft+followObj x)) { 
Var dx=(document.body.scrollLeft+followObj_x-followObj.offsetLeft)*adve: 
dx=(dx>071:-1)*Math.ceil(Math.abs(dx)); 
followObi.style.lefi=followObj.offsetLeft+dx: 
} 
if(followObj.offsetTop!=(document.body.scrollTop+followObj_y)) { 
var dy=(documentbody.scrollTop+followObj_y-followObij.offsetTop)*adve: 
dy=(dy>0?1:-1)*Math.ceil(Math.abs(dy)); 
followObi.style.top=followObj.offsetTop+dy: 


} 
followObj.style.display =": 
} 


var themotion= new motion(): 

themotion.addItem('followDiv1',200,200,'<a hre 人 ="http://wpa.qq.com/msgrd?V=1&Uin=228691050&Site= 在 线 咨询 &Menu=no" title=" 在 线 即 时 交谈 
"><img sre=./images/qqhelp.gif height=70 width="80" border=0></a>): 

themotion.playO: 


力 秘笈 心 法 


心 法 领悟 211: 使 用 document .write() 方 法 的 注意 事项 。 
调用 document.write0 方 法 的 结果 也 许 不 能 立刻 在 目标 浏览 器 窗口 中 显示 出 来 ， 这 是 因为 浏览 器 可 能 会 将 数 
据 缓存 起 来 ， 以 便 形 成 大 的 数据 块 输出 。 
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实例 212 


力 实例 说 明 


广告 作为 网 站 最 大 的 盈利 手段 ， 任 何 网 站 都 不 可 能 将 其 省 略 ， 那 么 ， 如 何 才能 实现 网 站 既 可 以 从 广告 中 获 
利 ， 又 能 使 用 户 流畅 地 阅读 网 站 信息 呢 ? 本 实例 将 介绍 如 何 制作 一 个 从 首页 右 下 角 弹 出 的 渐 显 广告 窗 体 ， 该 窗 
体 在 用 户 登录 网 站 时 自动 从 右 下 角 渐 渐 弹 出 ， 然 后 由 用 户 手动 关闭 。 本 实例 的 运行 结果 如 图 3.68 所 示 。 


| 


CW 编程 者 之 家 


忽 明 日 科技 服务 热线 : (04314978981 4978982 Email : 。 页 sual Basic 顷 生词 典 Delphi 注 得 语 册 ”三 ? 旦 程 启 秽 AsF Wet 闹 程 辣 风 FP 遇 程 疗 且 


和 明日 科技 向 您 推荐 


技术 支 圭 。。 会 员 中 心 。 软件 下 


图 3.68 右 下 角 渐 显 广告 


图 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 ，window 对 象 主要 用 于 在 HTML 中 打开 窗口 ， 应 用 极为 普 
遍 ， 但 也 有 一 些 缺陷 。 用户 浏览 器 决定 窗口 的 外 观 ， 设计 者 左右 不 了 其 窗口 的 大 小 及 样式 , 但 JavaScript 给 了 程 
序 这 种 控制 权 。 在 JavaScript 中 ， 可 以 使 用 window 对 象 来 实现 对 窗口 的 控制 。 


图 设计 过 程 
本 实例 主要 应 用 window 对 象 的 open0 方 法 打开 一 个 在 首页 右 下 角 弹 出 渐 显 的 广告 窗口 ,在 网 站 首页 中 添加 
如 下 代码 : 


<script language="javascript"> 
var newformW=300; 


i .open("advertise. ht "."width="+newformW+",height="+newformH+",top="+T+",left="+IL); 
} 


PPO: 
</script> 
力 秘笈 心 法 
心 法 领悟 212: window 对 象 打开 窗口 详解 。 
使 用 window 对 象 打开 窗口 的 语法 格式 如 下 : 
windowVar=window.open(url.windowname[.location]): 
参数 说 明 : 
windowVar: 当前 打开 窗口 的 句柄 。 如 果 open0 方 法 成 功 ， 则 windowVar 的 值 为 一 个 window 对 象 的 句柄 ， 


Bs 
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否则 windowVar 的 值 是 一 个 空 值 。 

wl: 目标 窗口 的 URL。 如 果 URL 是 一 个 空 字符 串 ， 则 浏览 器 将 打开 一 个 空白 窗口 ， 允 许 用 write0 方 法 创 
建 动态 HIML。 

windowname: window 对 象 的 名 称 。 

location: 对 窗口 属性 进行 设置 。 


3.7 状态 栏 设 计 


不 论 是 在 应 用 程序 还 是 在 网 页 中 都 会 应 用 到 状态 栏 ， 状 态 栏 可 为 用 户 提供 一 些 提示 信息 ， 如 当前 系统 的 日 
期 和 时 间 、 软 件 版 本 、 链 接地 址 、 系 统 信息 以 及 一 些 自 定义 信息 等 。 


力 实例 说 明 


浏览 网 页 时 ， 用 户 往往 更 加 注意 网 站 页 面 的 内 容 ， 而 不 会 过 多 注意 状态 栏 ， 如 果 为 页 面 的 状态 栏 添加 一 
些 特效 ， 一 定 会 给 网 站 增添 一 道 亮丽 的 风景 。 本 实例 实现 在 状态 栏 中 显示 跑马 灯 特效 文字 ， 运 行 结 果 如 图 3.69 
所 示 。 
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局 特 上 书 共 汪 关 注 | 


鞭 和 
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次 好 t 欢 加 沪 问 旺 巨 和 扶 图 书 同 站 客服 热 酉 : 0431-B49T8981 .| © 网 
3.69 跑马 灯 文 字 


力 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 的 status 属性 ， 并 通过 编写 自 定义 函数 设置 状态 栏 中 的 文字 
及 文字 属性 ， 通 过 站 ..else.…. 条 件 语 句 控制 文字 的 循环 显示 效果 。 
最 后 ， 在 <body> 标 记 中 调用 该 函数 ， 从 而 实现 状态 栏 中 的 跑马 灯 文 字 特效 。 
图 设计 过 程 
(1) 利用 JavaScript 脚本 编写 自 定义 函数 ， 生 成 状态 栏 中 的 文字 及 文字 属性 ， 代 码 如 下 : 
i 


Mit(s){ 
var text=" 您 好 ! 欢迎 访问 明日 科技 图 书 网 站 。 客 服 热线 : 0431-84978981" 


var 
(>210){ 
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out="scrollit("+s+")"; 
var timer Two=window.setTimeout(out,200); 


} 

clseif(s <=210&&s>0){ 
for (i=0;i<s:iH+){ 
Printtext+=" "; 


timerTwo=window.: i 


} 

elseif (s <=0){ 

f(s < textlength){ 
Printtext+=text.substring(-s,text.length); 


a et 
out="scrollit("+s+")"; 
timerTwo=window.setTimeout(out,200); 


timerTwo=window.setTimeout("serollit(100)".200): 
} 
} 


} 
</SCRIPT> 


(2) 在 <body> 标 记 中 调用 自 定义 的 函数 。 


<body onLoad="scrollit(100):"> 


国 秘笈 心 法 


心 法 领悟 213: window 对 象 的 status 属性 详解 。 


window 对 象 的 status 属性 的 语法 格式 如 下 : 
window.status 


status 属性 是 一 个 可 读 可 写 的 字符 串 ， 声 明 浏览 器 状态 栏 的 当前 内 容 。 
高 级 上 
实 斧 
实例 趣味 指数 : 裕 廊 全 本 
国 实例 说 明 


为 了 在 节省 网 页 空间 的 同时 更 好 地 服务 于 广大 的 用 户 ， 可 以 将 网 站 要 显示 的 简短 的 广告 信息 显示 在 状态 栏 
中 。 运 行 本 实例 ， 在 状态 栏 中 收缩 显示 明日 科技 公司 的 网 址 和 客服 热线 ， 运 行 结果 如 图 3.70 所 示 。 
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3.70 ”收缩 显示 文字 
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图 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 。 当 显 示 的 文字 总 长 度 等 于 该 文本 的 长 度 时 , 再 反方 向 滚动 文字 ， 
从 而 实现 在 状态 栏 中 收缩 显示 文字 。 


window 对 象 的 status 属性 的 语法 格式 如 下 : 

window.status 

属性 status 是 一 个 可 读 可 写 的 字符 串 ， 声 明了 浏览 器 状态 栏 的 当前 内 容 。 
图 设计 过 程 

本 实例 主要 通过 JavaScript 脚本 编写 状态 栏 中 收缩 显示 文字 特效 的 自 定义 函数 ， 完 整 代码 如 下 : 

<Script language=JavaScript> 

var text1=" 欢 迎 访 问 明日 科技 主页 ，www.mingrisoft.com"; 

comeback=0; 

cometo=0; 

window. status=text1.substring(0,cometo); 

1 


Someto--: 
ese 0) (eee 
else {cometot+:if(cometo—text] .Jength) {comeback=1}} 
window.status=text1.substring(0,cometo)+"( 客 服 热 线 : 0431-84978981)"; 
if(cometo=—textl length) {window.setTimeout("dis()",1000)} 
else {window.setTimeout("disO",50)} 
} 
dis(); 
</Seript> 
图 秘笈 心 法 
心 法 领悟 214: 状态 栏 。 
状态 栏 只 是 起 到 一 个 类 似 于 广告 的 作用 ， 但 它 比 其 他 的 弹出 层 广告 逊色 一 些 。 


2 | 


力 实例 说 明 


在 状态 栏 中 显示 数字 时 钟 是 个 性 化 网 站 所 特有 的 功能 ， 它 不 仅 可 以 节约 网 页 空间 ， 而 且 可 以 方便 用 户 时 时 
查看 。 本 实例 实现 在 状态 栏 中 显示 一 个 24 小 时 制 的 数字 时 钟 ， 运 行 结果 如 图 3.71 所 示 。 


有 
| Oi 有 


可 
册 拓 亲本 本 
图 3.71 状态 栏 显示 时 钟 
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图 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 实现 在 状态 栏 中 显示 数字 时 钟 ， 详 细 讲解 请 参考 实例 214。 


力 设计 过 程 


(1) 本 实例 主要 通过 JavaScript 脚本 开发 状态 栏 中 显示 动态 数字 时 钟 的 自 定义 函数 ， 代 码 如 下 : 


<script language="JavaScript"> 
var timerID = pull; 
var timerRunning = false; 


function stopelock Of 
f(t 


clearTimeout(timerID): 
timerRunning = false; 
} 


function showtime | { 
var now = new Date(); 
var hours = now.getHours(); 
var minutes = now.getMinutes(); 
var seconds = now.ge! 


var timeValue = "北京 时 间 : "+ ((hours >24) ? hours -24 :hours) 
ca 


timeValue += ((minutes < 10)? 
timeValue += ((seconds < 10) ? ":0" : ":" 
window.status = timeValue: 

timerID = setTimeout("showtimeO".1000): 
timerRunning = true; 


} 

fanction startclock 0 { 
stopclock(); 
这 


} 
</script> 


(2) 在 <body> 标 记 中 调用 自 定义 函数 startclock0， 代 码 如 下 : 


<body onLoad="startclock()"> 


力 秘笈 心 法 
心 法 领悟 215: JavaScript 脚本 中 时 间 的 设置 。 


在 JavaScript 脚本 中 设置 日 期 和 时 间 ， 首 先 要 实例 化 Date 类 ， 然 后 调用 其 中 的 方法 ， 获 取 对 应 的 日 期 、 时 


间 值 。 


3.8 导航 菜单 设计 


网 站 导航 菜单 对 于 每 个 网 站 都 是 必 不 可 少 的 ， 


它 相 当 于 城市 中 的 路 标 ， 可 以 指引 浏览 者 找到 自己 热衷 的 内 


容 。 导 航 菜单 有 很 多 种 ， 如 本 节 中 介绍 的 带 图 标的 文字 导航 条 、Flash 导航 条 、 按 钮 导航 条 、 弹 出 式 下 拉 菜 单 、 


二 级 导航 菜单 、 树 状 菜单 等 。 


图 实例 说 明 


OO 网 


高 级 | 
趣味 指教 : ododod| 


树 形 结构 能 够 以 层次 形式 展示 信息 ， 用 它 来 描述 具有 上 下 级 关系 的 内 容 再 恰当 不 过 。 本 实例 利用 菜单 的 树 
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形 结构 来 描述 企业 的 人 事 组 织 架构 ， 效 果 如 图 3.72 所 示 。 


图 3.72 树 形 导航 菜单 


图 关键 技术 


本 实例 中 实现 菜单 的 树 形 显示 是 通过 <table> 标 签 结合 DIV 实现 的 。 父 节点 利用 表格 来 显示 ， 子 节点 利用 
DIV 媒 套 表格 来 实现 。 这 样 做 的 目的 是 容易 对 子 节点 的 显示 和 隐藏 进行 控制 。 例 如 ， 当 用 户 单 击 父 节 点 时 ， 如 
果子 节点 没有 展开 , 将 DIV 设置 为 可 见 就 可 以 显示 子 节点 ; 如 果子 节点 可 见 , 将 DIV 设置 为 不 可 见 就 可 以 隐藏 
子 节 点 。 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ,在 表格 的 第 2 行 再 添加 一 个 2 行 2 列 的 表格 。 表 
格 的 第 1 列 用 于 显示 节点 前 的 图 标 ， 第 2 列 描述 节点 文本 ， 主 要 代码 如 下 : 


<form id="forml" name="form1" method="post" action=" > 
<table width="372" border="1" align="center” © bgcolor="#E6F2F2" bordercolor="#478DSD" 
style="border-style:none" cellspacing="0" > 
<tr> 
<td scope="col" align="center" style="border-bottom-style:none" > 人 事 组 织 架构 <ltd> 


</tr> 
<tr> 
<td> 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left"> 
<?php / 赔 入 PHP 脚本 
Sxml file = simplexml load_file("org.xml"); /1/ 从 XML 文件 中 加 载 节点 
foreach($xml_file->children() as Snode){ // 遍 历 根 节点 
?> 
<t> 
<td width="38%" align="right"> /设置 节点 图 标 
<img sre="images/rootnode.gif" width="15" height="15" border-"0"> </img> 
<htd> 
<td width="62%" left="0px" align="left" ><a href="#" onclick= "ShowNode(<?php echo $node ?>)">&nbsp:&nbsp:; 
<?php echo $node ?></a> // 设 置 节点 文本 
<htd> 
</tr> 
<t> 


<td width ="38%" align="center" > 
<itd> 


<td width ="62%" > 
<div id= <?php echo $node ?> style ="display:none" class="HideDiv" > // 定 义 DIV 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left" > 
<?1 


foreach($node->childrenO) as Svalue){ /遍历 子 节点 
?> 


<t> 
<td width ="10%" align="right" > 
<img sre="images/childnode.gif’ width="15" height="15" border="0" > </img> 

<ftd> 

<td width="90%" align="left ><a href-"#" >&nbsp:&nbsp:<2php echo $value?></a> 
<ftd> 

</> 

<?php 
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<div> 
<hd> 
</r> 
<?php 
} 
?> 
</table> 
<htd> 
</> 
</table> 
<script language="javascript"> 
function ShowNode(ParentID) { /隐藏 或 显示 子 节点 


var Div = ParentID; 
if (Div.style.display — "none"){ 

Div.style.display = "block"; // 显 示 DIV， 以 此 来 显示 子 节点 
jelse if (Div.style.display 一 "block"){ 

Div.style.display = "none"; /隐藏 DIV， 间 接 隐 藏 子 节点 


(3) 人 事 组 织 的 架构 存储 于 XML 文件 org.xml 中 。 
图 秘笈 心 法 


心 法 领悟 216， 动态 设置 超 链接 。 
在 设计 网 站 项 目 时 ， 有 时 需要 根据 实际 情况 动态 设置 超 链 接 的 内 容 。 在 利用 <a> 标 签 定义 超 链接 时 可 以 结合 


PHP 脚本 来 实现 这 一 功能 ， 例 如 : 
<a href="#" onclick= "ShowNode(<?php echo $node ?>)">&nbsp:&nbsp; <?php echo Snode ?></a> 


趣味 指数 : 请 寅 良 请 | 


力 实例 说 明 


在 网 站 中 不 仅 可 以 设置 导航 条 ， 而 且 还 可 以 设置 导航 菜单 。 由 于 菜单 内 容 比较 多 ， 在 同一 页 面 中 显示 会 比 
较 杂 乱 ， 所 以 目前 多 数 设计 者 都 采用 收缩 式 的 导航 菜单 。 运 行 本 实例 ， 当 浏览 者 单 击 “ 网 站 管理 ”时 ， 在 其 下 
方 将 弹出 导航 菜单 ， 如 图 3.73 所 示 ， 浏 览 者 再 次 单 击 “ 网 站 管理 ”时 ， 导 航 菜单 又 收缩 回去 ， 页 面 中 不 再 显示 
菜单 中 的 内 容 。 


~ 
人 功 双亲 单 


后 台 管理 首页 /退出 < 


同 站 管理 Q 
初始 化 信息 
服务 器 信息 


3.73 ”收缩 式 菜单 


图 关键 技术 


本 实例 主要 是 利用 显示 、 隐 藏 表格 来 实现 收缩 式 导航 菜单 的 功能 。 单 击 导航 菜单 ， 显 示 当前 菜单 的 内 容 ， 
隐藏 上 一 个 显示 的 菜单 。 在 隐藏 菜单 时 ， 让 其 有 规律 地 隐藏 进而 实现 动画 效果 。 
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四 设计 过 程 


(1) 显示 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
fanction show(obj.maxg,0bj2){ 
if(obj.style.pixelHeight<maxg) { 
obj.style pixelHeight+=maxg/10; 
obi filters.alpha.opacity+=20; 
obj2.background="images /title_hide.gif’; 
iobj.style pixelHeight 一 maxg/10) 
obj.style.display="block’; 
myObij=obi; 


myObj2=obj2; 
setTimeout(show(myObj.mymaxgmyObj2).57: 
} 


} 
</SCRIPT> 


(2) 隐藏 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function hide(objmaxg,obj2){ 
if(obi.style.pixelHeight>0) { 
if(obj.style.pixelHeight—maxg/5) 
obj.style.display='none'; 
obj.style.pixelHeight-=maxg/S; 
obi filters.alpha.opacity-=10; 
obj2.background="images/title_show.gif"; 
myObj=obj; 
mymaxg—maxg 
myObj2=obj2; 
setTimeout(hide(myObjmymaxgmyObj2).57): 
} 


else 
if(whichContinue) 
whichContinue.click(); 


Di 
(3) 单 击 菜单 上 的 文字 时 ， 隐 藏 前 一 个 菜单 ， 显 示 当 前 菜单 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function chang(obi,maxg.obi2){ 
if(obj.style.pixelHeight) { 
hide(objmaxg.obj2); 


else 
这 mopen){ 
whichContinue=obj2; 
nopen click(: 


clse{ 
show(objmaxg.obj2): 
nopen=obi2: 
whichContinue="; 
} 
} 
</SCRIPT> 
(4) 在 表格 的 相关 鼠标 事件 中 调用 自 定义 的 方法 和 属性 来 改变 收缩 菜单 的 显示 和 隐藏 ， 代 码 如 下 : 
<TD class=list_title id-listl «onmouseover="this.typename=list_title2':” ©onclick=chang(menu1.60,listl): onmouseout="this.typename="ist_title';" 
background="images/title_hide.gif” height=25><SPAN> 网 站 管理 </SPAN> </TD> 


心 法 领 司 217: 收缩 式 导航 菜单 。 
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PHP 开发 实例 大 全 (基础 卷 ) 
收缩 式 导航 菜单 是 笔者 最 喜欢 的 导航 菜单 ,虽然 只 是 由 一 些 JavaScript 事件 组 成 , 但 是 操作 时 的 动态 效果 


| 
高 级 | 
起 呆 林 才 ! 南 页 宽 wx 


力 实例 说 明 


对 于 一 个 企业 网 站 来 说 ，“ 联 系 我 们 ”导航 条 是 必 不 可 少 的 。 为 了 更 加 引 人 注 意 ， 可 以 将 其 制作 成 具有 展 
开 式 动画 效果 的 导航 条 。 运 行 本 实例 ， 可 以 看 到 页 面 右 侧 的 “联系 我 们 ”导航 条 是 逐渐 展开 的 ， 并 且 每 次 刷新 
页 面 时 ， 都 会 以 同样 的 动画 效果 展开 ， 展 开 效 果 如 图 3.74 所 示 。 


图 3.74 展开 式 导航 条 


力 关键 技术 


本 实例 主要 是 通过 自 定义 JavaScript 函数 控制 图 片 (image) 对 象 的 height 属性 值 实现 的 。 为 了 实现 动画 效 
果 ， 在 JavaScript 函数 中 还 需要 应 用 setTimeout( 方 法 延迟 执行 改变 图 片 高 度 的 操作 。 


图 设计 过 程 
(1) 在 网 页 中 显示 “联系 我 们 ”导航 条 的 位 置 插入 一 张 全 部 展开 后 的 “联系 我 们 ”导航 图 片 ， 在 需要 设置 
超 链接 的 文字 上 添加 图 片 热点 并 设置 相应 的 超 链接 。 


(2) 将 图 片 的 height 属性 值 设 置 为 0，name 属性 设置 为 our。 
(3) 编写 自 定 义 的 JavaScript 函数 ourmove0， 用 于 实现 图 片 的 展开 效果 。ourmoveO 函 数 的 代码 如 下 : 


<script language="javascript"> 

function ourmoveO{ 

if(our height<163){ 
‘our.height=our.height+3 
setTimeout(ourmove.1) 

} 


</script> 
(4) 在 当前 页 面 的 最 底部 也 就 是 </body> 标 记 之 前 ， 添 加 如 下 代码 实现 导航 条 的 展开 式 动画 效果 。 
<script language="javascript"> 
‘ourmove(); 
</script> 


国 秘笈 心 ; 


心 法 领悟 218: 使 用 ourmove0 函 数 的 注意 事项 。 
一 定 要 将 调用 ourmove0 函 数 的 代码 放 在 </body> 标 记 之 前 ， 否 则 页 面 的 其 他 内 容 需 要 等 动画 显示 完毕 才 可 
以 显示 ， 达 不 到 预期 的 效果 。 
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力 实例 说 明 


在 设计 网 站 的 导航 菜单 时 ， 有 时 为 了 让 用 户 快速 了 解 菜 单 导航 的 详细 内 容 ， 需 要 为 菜单 设置 提示 信息 。 这 
样 当 用 户 鼠 标 移动 到 菜单 项 上 时 就 会 显示 提示 信息 ， 效 果 如 图 3.75 所 示 。 


明日 图 书 ”编程 社区 企业 简介 ”意见 反馈 | 
力 因 书 用 户 提供 在 和 和 旦 溉 务 


图 3.75 解释 型 菜单 


图 关键 技术 


本 实例 主要 应 用 超 链接 中 的 title 属性 实现 解释 型 菜单 。 在 定义 超 链接 时 为 其 设置 title 属性 ， 就 可 以 实现 菜 


单 的 提示 功能 ， 例 如 
<a href="#" title = "为 图 书 用 户 提供 在 线 答疑 服务 "> 明日 图 书 &nbsp;&nbsp; <a> 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 表格 的 第 2 行 再 添加 一 个 1 行 4 列 的 表格 。 


(3) 在 霸 套 的 表格 中 加 入 超 链接 ， 主 要 代码 如 下 : 
<td width="123" scope="col" align="right"> <a href="#" title = "为 图 书 用 户 提供 在 线 答疑 服务 "> 明日 图 书 &nbsp;&nbsp; </a></td> 
<td width="79" scope="col" ali "><a href="#" title = "为 编程 人 员 提 供 一 个 在 线 交流 平台 "> 编程 社区 &nbsp;&nbsp:</a></td> 
<td width="78" scope="col" align="right"><a href="#"> 企 业 简介 &nbsp:&nbsp:</a></td> 
<td width="82" scope="col" align="right"><a href="#"> 意 见 反馈 &nbsp;&nbsp;</a></td> 


图 秘笈 心 法 


心 法 领悟 219: 使 用 CSS 样式 统一 超 链接 效果 。 
在 设计 表单 页 面 时 ， 通 常 需要 统一 某 一 类 表单 元 素 的 效果 。 例 如 ， 统 一 超 链 接 文本 字体 的 大 小 、 文 本 颜色 
等 。 一 种 简单 的 方式 是 利用 CSS 样式 来 实现 ， 例 如 


<style> 


af 
font-size:16px: 
ee 


这 样 页 面 中 的 超 链接 字体 均 为 16 个 像素 ， 颜 色 为 哨 红 色 。 


: 


趣味 指数 : 但 广 食 全 S| 


实例 220 


力 实例 说 明 


网 站 中 的 导航 菜单 是 网 站 首页 必 不 可 少 的 表单 元 素 ， 美 观 、 新 颖 的 导航 菜单 会 为 网 站 增色 许多 。 本 实例 将 
实现 一 个 半 透 明 效果 的 菜单 ， 效 果 如 图 3.76 所 示 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


网 站 导航 技术 支持 


Tema 
ena 


| 明日 图 书 | 明日 软件 | 编程 体验 | 编程 资源 | 内 部 论坛 | 


3.76 半 透 明 效果 菜单 


图 关键 技术 


半 透 明 效 果 的 菜单 可 以 通过 CSS 样式 中 的 滤 镜 filter 来 实现 。 在 滤 镜 中 使 用 alpha 属性 设置 透明 程度 (范围 


为 0~100，0 表示 完全 透明 ，100 表示 不 透明 ) ， 其 语法 格式 如 下 : 
{Filter:alpha(opacity=opacity, finishopacity=finishopacity.sytle=sytle.startx=startx,starty=starty, finishx=finishx, 
finishx=finishyx)} 
例如 ， 下 面 的 语句 将 滤 镜 透明 度 设置 为 50%。 

Filter: Alpha(Opacity=50): 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 第 2 行 中 再 添加 一 个 1 行 3 列 的 表格 。 
(3) 定义 CSS 样式 表 ， 设 置 超 链 接 的 效果 和 半 透 明 菜 单 的 效果 ， 代 码 如 下 : 


<style type="text/css"> 

At 

COLOR: blue; FONT-SIZE: 10pt; TEXT-DECORATION: none:color:#FF6600 
} 


A:hover { 
COLOR: black; FONT-SIZE: 10pt:color:#395531 
} 
,transMenu { 
BORDER: #666666 1px solid; 
FONT: 12px Verdana; 
POSITION: absolute; 
background-image:url("images/item out.ipg"); 
background-repeat : repeat-y; 
Filter: Alpha(Opacity=50); 
} 


</style> 


(4) 利用 JavaScript 脚本 控制 菜单 的 显示 与 隐藏 ， 代 码 如 下 : 
<script language="javascript"> 
function ShowMenu(divID, menultem){ // 显 示 子 菜单 
if(document.al){ 
switch (menultem){ 
case ' 网 站 导航 ': 


{ 
var htmltxt = "<a href = 'www.mingribook.com'> 明日 图 书 网 站 </a> <br> <a href= 
"www.mrbced.cn'> 明日 编程 社区 </a> <br> <a href= "www.mrsoft.com'> 明日 软件 </a> <br>"; 


MenuID innerHTML = htmltxt: /设置 DIV 代码 
MenuID style padding = "Spx"; /设置 DIV 边 距 
MenuID style height = "SSpx"; // 设 置 DIV 高 度 
break: 

} 

case 技术 支持 ': 


var menutxt = "<a href = "www.mingribook.com’> QQ </a> <br> <a href = wwwmrbcedcn> 
MSN </a> <br> <a href = "www.mrsoft.com’> Phone </a> <br>"; 


MenuID innerHTML = menutxt: // 设 置 DIV 代码 
MenulD.style .padding = "Spx"; /设置 DIV 边 距 
MenulD .style height = "5Spx": /设置 DIV 高 度 
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break: 
} 


中 
/设置 菜单 显示 位 置 
MenulD .style.left = document.body.scrollLeft + event.clientX - eventoffsetX: 
MenulD style.top = document.body.scrollTop + event.clientY - event.offsetY + 18 ; 
MenulD.style.display = "block": 
} 
function HideMenu){ // 隐 藏 子 菜 单 
if(document.al){ 
MenulD style.display = "none"; /隐藏 DIV 
} 


(document.al){ 
document.onmousemove = HideMenu; // 鼠 标 在 表单 中 移动 时 隐藏 菜单 

} 

<lscript> 


心 法 领悟 220: 设置 鼠标 移动 到 超 链接 的 效果 。 
在 使 用 超 链 接 时 通常 会 为 超 链接 设置 一 些 特效 。 例如 ， 当 用 户 鼠 标 移动 或 单 击 超 链接 时 文本 颜色 发 生变 化 。 
要 实现 这 一 功能 最 简单 的 方式 是 定义 CSS 样式 表 ， 例 如 : 


Athover { 
FONT-SIZE: 10pt: 
color:#395531 

} 


i 四 
实例 说 明 


二 级 导航 菜单 是 许多 网 站 通常 采用 的 菜单 导航 形式 。 项 行 显示 一 级 菜单 ， 其 下 显示 二 级 菜单 。 当 用 户 选择 
不 同 的 一 级 菜单 时 ， 二 级 菜单 会 动态 发 生变 化 。 本 实例 就 实现 这 种 效果 的 导航 菜单 ， 如 图 3.77 所 示 。 


Visual C++ | Visual Basic | PHP 


图 3.77 二 级 导航 菜单 


力 关键 技术 


实现 二 级 导航 菜单 的 关键 是 二 级 菜单 的 显示 。 当 用 户 选择 不 同 的 顶层 菜单 时 需要 显示 不 同 的 二 级 菜单 。 这 
里 我 们 用 DIV 作为 二 级 导航 菜单 的 容器 ， 通 过 动态 设置 DIV 对 象 的 innerHTML 属性 来 实现 动态 显示 二 级 菜单 
的 效果 。 

看 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ， 在 第 1 行 中 再 添加 一 个 1 行 4 列 的 表格 ， 在 第 2 
行 再 添加 一 个 1 行 2 列 的 表格 。 表 单 代码 如 下 : 


<form id="form1" name="forml”" method="post" action=""> 
<table width="610" height="441" border="0" align="center"> 
<t> 
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<th height="62" align="right" valign="bottom" scope="col"><table width="337" border="1" align="right" cellpadding="0" cellspacing="0" 
bordercolor="#993399" background="images/menuBK JPG"> 
<t> 
<td width="327" scope="col"> <a href =# onmousemove= MenuCtrl( 论 坛 中 心 'subMenu):> 论 坛 中 心 <a><ltd> 


<td width="327" scope="col"><a href = 当 onmousemove=MenuCtrl(' 勘 误 发 布 'subMenu'):> 勘 误 发 布 <a></ltd> 
<td width="327" scope="col"><a href = 党 onmousemove=MenuCtrl(' 作 品 展示 ''subMenu);> 作 品 展示 </a></td> 
<td width="327" scope="col"><a href = 党 onmousemove=MenuCtrl( 联 系 我 们 ','subMenu'):> 联 系 我 们 </a></td> 
<lt> 
<ltable></th> 
<> 
<tr valign="top"> 
<td height="373"><table width="606" border="0" align="center"> 
<tr> 
<th width="283" scope="col">&nbsp:</th> 
< 由 width="313" seope="col"><div id="subMenu" align="left"></div></th> 
<l> 
</table></td> 
</> 
</table> 
</form> 
(3) 利用 JavaScript 脚本 控制 二 级 菜单 的 显示 ， 代 码 如 下 : 
<script lan 
var curSel ="": 
function MenuCtrl(menuID, divID){ 
var divObj = document.getElementById(divID); /获取 DIV 对 象 


switch (menuID){ /判断 项 层 菜单 
case "论坛 中 心 ': 


/在 DIV 中 显示 子 菜单 

divObj innerHTML = "<a href = #>Visual C++ |<a href = '#> Visual Basic |<a href = #'> PHP </a>"; 
eurSel = 论坛 中 心 '; 

brealk 


} 
case ' 勘 误 发 布 : 
{ 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = > 光盘 错误 |<a href= 风 > 文档 错误 |<a href= %> 目 录 错 误 </a>"; 
eurScl= ' 勘 误 发 布 : 
break 


} 
case 作品 展示 ': 
: 
/在 DIV 中 显示 子 菜单 


divObj.innerHTML = "<a href = 风 > 视 频 学 VB |<a href= 风 > 视频 学 VC |<a href=#> 
视频 学 Asp net |<a hre 全 迪 > 视频 学 C# </a>"; 


eurSel = ' 作 品 展 心 ; 
break: 
} 
case ' 联 系 我 们 ': 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = #>0ICQ [a href = > MSN|<a href = #> Phone</a>"; 
eurSel = 联系 我 们 ': 
break: 
} 
| 
让 (documentalD{ 
MenuCtrl( 论坛 中 心 'sobMenu'): // 上 默认 情况 下 显示 第 一 个 顶层 菜单 的 二 级 菜单 项 
} 
<Jscript> 
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秘笈 心 法 
心 法 领悟 221: 设置 表格 单 边框 效果 。 


默认 情况 下 ， 表 格 具有 双边 框 ， 在 利用 表格 进行 界面 布局 时 这 种 效果 会 影响 页 面 的 美观 性 ， 可 以 通过 将 表 
格 的 cellspacing 属性 设置 为 0 来 实现 表格 的 单 边 框 效果 ， 例 如 : 


<table width="337" border="1" cellspacing="0" bordercolor="#993399" background="images/menuBK.JPG"> 


Wo 


力 实例 说 明 


导航 条 是 网 站 设计 中 不 可 缺少 的 元 素 之 一 ， 它 能 正确 地 引导 浏览 者 查找 需要 的 资料 ， 成 为 浏览 者 的 网 站 路 
标 。 同 时 网 页 导航 条 的 设计 风格 也 能 影响 到 页 面 的 整体 风格 ， 对 于 一 个 静态 元 素 居多 的 页 面 ， 可 以 为 导航 条 添 
加 动态 效果 ， 这 样 可 以 使 整个 网 站 不 至 于 太 呆板 ， 增 强 网 页 的 欣赏 价值 。 例 如 ， 在 明日 实业 网 站 中 ， 笔 者 将 导 
航 条 设计 成 动画 效果 ， 用 户 将 鼠标 移动 到 任意 一 个 导航 按钮 上 时 ， 该 按钮 都 会 突出 显示 ， 鼠 标 移出 后 ， 又 恢复 
为 原来 的 位 置 ， 运 行 结 果 如 图 3.78 所 示 。 


图 3.78 ”导航 条 的 动画 效果 


力 关键 技术 


本 实例 主要 是 通过 Image 对 象 的 鼠标 事件 控制 Image 对 象 的 sre 属性 的 值 实现 的 。 

在 JavaScript 里 提供 了 对 图 像 进行 处 理 的 专用 对 象 Image 来 装 入 文档 的 图 形 。Image 对 象 与 其 他 对 象 的 差别 
在 于 ,其 允许 通过 构造 器 显示 和 创建 新 的 Image 对 象 ,创造 和 预 装 入 的 图 形 之 前 并 非 Web 页 面 的 组 成 部 分 .Image 
对 象 存在 于 浏览 器 的 缓冲 区 中 ， 用 于 蔡 换 已 经 显示 的 图 像 。 

用 Image 构造 器 创建 图 形 的 语法 格式 如 下 : 


ObjImg=new image() /创建 了 一 个 新 的 Image 对 象 ， 并 将 其 赋予 变量 ObjImg 
ObjImg.sre=" 图 片 文件 相对 路 径 " /设置 Image 对 象 的 Sre 属性 
图 设计 过 程 


(1) 准备 14 张 图 片 。7 张 鼠标 移出 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 +.gif”，7 张 鼠 标 
移入 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 + _over.gif”。 

(2) 将 准备 的 7 张 鼠 标 移出 时 显示 的 图 片 按 顺序 插入 页 面 中 的 适当 位 置 , 并 设置 其 鼠标 事件 onMouseMove 
和 onMouseout 执行 的 操作 ， 这 里 分 别 调用 两 个 不 同 的 自 定义 JavaScript 函数 ， 关 键 代码 如 下 : 


<img sre="Images/top/menu_01.gif' id="image1" width="95" height="119" border="0" onMouseMove="move(this'1)" onMouseout="out(this'1')"> 
<img sre="Images/top/menu_02.gif" id="image2" width="95" height="119" border="0" onMouseMove="move(this.2)" onMouseout-"outtthis.2)"> 
<img sre="Images/top/menu_03.gif" name="image3" width="95" height="119" border="0" onMouseMove="move(this,3')" 
onMouseout="out(this.'3)"> 

<img sre="Images/top/menu 04.gif' name="image4" width="94" height="119" border="0" onMouseMove="move(this.4)" onMouseout="out(this.4")"> 
<img sre="Images/top/menu_05.gif" name="image5" width="95" height="119" border="0" onMouseMove="move(this,'$)" onMouseout="out(this,5)"> 
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<img sre—"Images/top/menu_ 06.gif" name—"image6" width="94" height="119" border="0" onMouseMove—"move(this:6')" onMouseout="out(this,6)"> 
<img sre="Images/top/menu_07.gif’ width="95" name="image7" height="119" border="0" onMouseMove="move(this,7")" onMouseout="out(this,7)"> 
(3) 编写 自 定义 的 JavaScript 函数 move0 和 out0，move0 函 数 用 于 设置 鼠标 移入 导航 按钮 时 显示 的 图 片 ， 
outO 函 数 用 于 设置 鼠标 移出 导航 按钮 时 显示 的 图 片 ， 代 码 如 下 : 
<script language="javaseript> 
// 和 鼠标 移动 效果 
var A_Img=new Image0; 
function move(image.num){ 
image.sre=Tmages/top/menu 0'+num+’ over.gif; 


function out(image.num){ 
image src=Tmagesltop/menu_0+numt'gif; 
</script> 


心 法 领悟 222: Image 构造 器 。 
在 利用 Image 对 象 编程 之 前 ,利用 <img> 标 记 显 示 属 性 。 在 HTML 中 ,要 显示 图 片 可 以 用 如 下 语句 来 实现 : 


<img sre="pictureName.gif" name="ImgName"> 


在 JavaScript 中 可 以 用 下 面 的 方式 访问 Image 对 象 : 


document Img.src=" menu_01.gif' 
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第 4 章 文件 操作 


4.1 文件 上 传 


文件 上 传 是 网 站 中 一 个 非常 重要 的 功能 ， 特 别 是 在 网 站 的 后 台 管理 系统 中 ， 需 要 通过 此 功能 向 网 站 中 上 传 
很 多 数据 ， 包 括 图 片 、 文 件 等 。 


Ce 


实例 223 趣味 指数 ; 三 丰 从 


力 实例 说 明 


文件 的 上 传 可 以 分 为 两 类 : 一 类 是 上 传 文件 到 服务 器 ， 即 存储 到 服务 器 指定 的 文件 夹 下 ; 另 一 类 是 将 数据 
以 二 进 制 的 形式 上 传 到 数据 库 中 。 具 体 采用 哪 种 方式 ， 需 要 根据 程序 的 实际 需要 而 定 。 

本 实例 中 将 介绍 如 何 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 中 ， 并 且 输 出 上 传 的 数据 。 运 行 结果 如 图 4.1 
所 示 。 
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图 4.1 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 


力 关键 技术 
本 实例 主要 应 用 表单 中 的 文件 域 提交 图 片 文件 ， 代 码 如 下 : 


<input name="cover" type="file" id="cover" size="30"> 
其 中 ， 参 数 type 指定 表单 元 素 的 类 型 为 文件 域 ，name 指定 表单 元 素 的 名 称 ; size 指定 表单 元 素 的 大 小 。 
通过 $_POST 方法 获取 表单 中 提交 的 数据 ， 并 应 用 insert 语句 将 表单 中 的 数据 添加 到 数据 表 中 。insert 语句 
的 语法 如 下 : 


Insert into table_name (column_namel.column name2. ... ) values (valuel, value2. ... ) 
参数 说 明 : 

table name: 数据 表 的 名 称 。 

column_namel: 数据 表 中 字段 的 名 称 。 
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valuel: 表单 提交 的 变量 。 

在 index_ok.php 文件 中 ， 通 过 fopen0 函 数 和 fread() 函 数 读 取 表 单 中 提交 的 图 片 数 据 ， 并 且 将 返回 的 数据 存 
储 到 数据 库 中 。 

在 这 里 要 特别 注意 网 页 编码 格式 的 使 用 。 如 果 网 页 的 编码 格式 是 UTF-8， 那 么 在 获取 上 传 文件 的 存储 路 径 
时 ， 必 须 将 UTF-8 编码 格式 的 字符 串 转换 为 GB2312 编码 格式 ， 否 则 文件 不 能 被 fppen0 函 数 读 取 。 


图 设计 过 程 
(1) 通过 Dreamweaver 开发 工具 创建 一 个 index.php 页 , 添加 一 个 表单 ,设置 表单 的 method 属性 值 为 post， 
Action 属性 值 为 ndex_ok.php; 添加 表单 元 素 ， 提 交 图 书信 息 ， 添加 提交 按钮 ， 其 关键 代码 如 下 : 


<form name="form" method="post" action="index_ok.php" onSubmit="return check_form(this)"> 
<input name="cover" type="file" id="cover" size="30"> 
<input type="submit" name="Submit" value=" 提 交 "> 
</form> 
(2) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 连 接 MySQL 数据 库 服务 器 ， 连 接 db_database04 数据 库 ， 设 
置 数 据 库 变 量 格式 为 utf8。 
(3) 创建 index_ok.php 文件 ,通过 $_POST 方法 获取 表单 中 提交 的 数据 ， 并 判断 上 传 图 片 的 格式 是 否 正 确 ， 


通过 fopen0) 函 数 和 fread0 函 数 读 取 表单 中 提交 的 图 片 数 据 ， 编 写 insert 语句 将 数据 添加 到 指定 的 数据 表 中 ， 其 


关键 代码 如 下 : 
<?php 
include ("conn/conn.php"); // 连 接 数据 库 
Sbookname =$_POST["bookname"]; // 获 取 表单 中 提交 的 数据 


Sprice =$_POST["price"]; 
Smaker =$_POST["maker"]: 
SissuDate = date("Y-m-d H:i:s"); 
Spublisher =$_POST["publisher"]; 
$synopsis = $_POST["synopsis"]: 
if($ POSTI"Submit"] =— true) { 
Scover = $_FILES["cover"][‘name']: 1/ 获取 表单 中 提交 的 图 片 
Scover_type = strstr($cover, "."); /获取 从 “.” 到 最 后 的 字符 
if (Seover type != "jpg" && Scover type (= "gif && Scover type = 
"JPG" && $cover type !=".GIF" && $cover_type != ".bmp" && Scover type (= 
.BMP { 1/ 判断 图 片 的 格式 
echo "<script>alert(' 封 面 图 片 格式 不 对 ， 请 进行 处 理 后 在 上 传 ! ): window.location href='index.php';</script>"; 
}else{ 
Scover=iconv("utf-8","gb2312",$coven): 1/ 设置 字符 串 的 编码 格式 
Spath = "uploadfiles/".Scover: 
@move_uploaded_file($_FILES["cover"]["tmp_name"].$path): 


$fp = fopen($path, "tb"); /以 二 进 制 形式 打开 图 片 
Simage = addslashes( 

@fread($fh. filesize($path))): // 读 取 二 进 制 的 数据 

// 将 数据 添加 到 指定 的 数据 表 中 


$sql = "insert into 
tb_book(bookname,price.maker.issuDate.publisher,synopsis.cover)values('‘$bookname','$price','$maker','$issuDate','$publisher','$synopsis','$image’)"; 
Sresult = mysql query($sql, 
$conn); 
if ($result — true) { 
echo iconv("utf-8",."gb2312"," 文 件 上 传 成 功 11"); 
echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; 
}else{ 
echo iconv("utf-8","gb2312"," 文 件 上 传 失败 11"); 
echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; 
1 
大 
} 


> 
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心 法 领悟 223: 读 取 数据 库 中 存储 的 二 进 制图 片 数据 。 
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读 取 数 据 库 中 存储 的 二 进 制图 片 数据 需要 定义 一 个 单独 的 文件 ， 根 据 数据 的 ID 值 执行 查询 ， 并 应 用 
mysql reultO 函 数 返 回 查询 结果 ， 最 后 输出 查询 结果 。 本 实例 中 定义 的 是 images.php 文件 ， 通 过 该 文件 完成 对 数 
据 库 中 存储 的 二 进 制图 片 的 读 取 操 作 。images.php 的 代码 如 下 : 

php 


include ("conn/conn.php"); // 连 接 数据 库 
Squery = "select + from tb_book where id=" . $_GET[recid]:; // 定 义 查询 指定 数据 的 语句 
Sresult = mysql_ query($query): // 执 行 查询 
if(! $result) 

die("error: mysql query"): // 返 回 失败 的 结果 
Snum = mysql_num_rows($result); // 获 取 查 询 结果 的 数量 
($num <1) 

die("error: no this recorder"); // 如 果 查 询 结果 小 于 则 说 明 没有 数据 
S$data = mysql_result($result 0, "cover"): // 获 取 查 询 结 果 
mysql_close($conn); // 关 闭 数据 库 
echo $data; /| 输出 返回 的 数据 


?> 


高 级 | 
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力 实例 说 明 

在 开发 网 站 的 过 程 中 ， 不 但 可 以 将 文件 上 传 到 数据 库 中 ， 而 且 可 以 将 文件 上 传 到 服务 器 ， 这 种 方式 可 以 为 
网 站 中 的 数据 库 节 省 很 多 空间 ， 同 时 可 以 控制 上 传 文件 的 大 小 、 格 式 ， 并 且 读 取 服务 器 中 的 文件 要 比 从 数据 库 
中 读 取 方 便 很 多 。 运 行 本 实例 ， 如 图 4.2 所 示 ， 单 击 图 中 的 “浏览 ”按钮 ， 选 择 要 上 传 的 文件 ， 然 后 单 击 “ 提 
交 ” 按 钮 ， 如 果 上 传 成 功 ， 则 在 页 面 中 提示 “上 传 成 功 ! ”， 和 否则 给 出 错误 提示 信息 。 


一 个 此 人 nins 
CR 


达 挥 上传 文件 : end_Franevork_7H. chn 攻守 


上 传 图 片 


上 传 错误 :上 传 文件 大 小 超出 配置 文件 规定 值 
cepyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


4.2 ”上传 文件 


力 关键 技术 


在 PHP 中 ,应 用 move_uploaded file0 函 数 实 现 将 文件 上 传 到 指定 文件 夹 。 但 是 ， 在 执行 文件 上 传 之 前 , 为 
了 防止 潜在 的 攻击 对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 , 可 以 先 应 用 is_uploaded file0 函 数 判断 指定 的 
文件 是 否 通过 HITP POST 上 传 ， 如 果 是 则 返回 TRUE。is_uploaded file0 函 数 的 语法 如 下 : 

boolis_uploaded_file ( string filename ) 

参数 filename 必须 指定 类 似 于 $_FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 
$_ FILES[filename'][name'] 。 

通过 is_uploaded file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 
件 ， 如 /etc/passwd。 

move_uploaded file0) 函 数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返回 TRUE， 否 则 返回 FALSE， 其 
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语法 如 下 : 


bool move uploaded file ( string filename, string destination ) 


参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指定 文件 上 传 后 保存 的 


新 路 径 和 名 称 。 


| 说 明 :如 果 参 数 filename 不 是 合法 的 上 传 文件 ,不 会 出 现任 何 操作 ,move_uploaded file0 函 数 将 返回 FALSE。 
如 果 参 数 filename 是 合法 的 上 传 文件 ， 但 出 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ， 
move_uploaded file0) 函 数 将 返回 FALSE， 并 且 还 会 发 出 一 条 警告 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 添 加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 


使 用 POST 方法 ， 将 表单 中 的 数据 提交 到 本 页 。 


(2) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完 成 图 片 的 上 传 ， 代 码 如 下 : 


<?php 
if(!empty($_FILES[up_picture][name]){ 
if($_FILES['up_picture']['error]>0){ 
echo "上 传 错误 :"; 
switeh($_FILES['up_picture][ error){ 


ase 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 


case 3: 
echo "上 传 文件 不 全 "; 
break: 


case 


本 
echo "没有 上 传 文件 "; 


} 
yelse{ 
(is_dir(",/upfile/)){ 
mkdir("./upfile/"); 


} 
$path=' /upfile/' time().strstr($_FILES['up_picture [name],.); 
if(is_uploaded file($_FILES['up_picture']['tmp_name']){ 
if(!Imove_uploaded_file($_FILES['up_picture']['tmp_name'],$path)) { 
echo "上 传 失败 ": 
jelse{ 


// 判 断 上 传 内 容 是否 为 空 
// 判 断 文 件 是 否 可 以 上 传 到 服务 器 


// 判 断 指定 目录 是 否 存 在 
// 创 建 目录 


// 定 义 文件 名 称 和 存储 位 置 
// 是 否 通过 HTTP POST 上 传 
/执行 上 传 


echo "文件 ".time().$_FILES['up_picture']['name']." 上 传 成 功 ， 大 小 为 :".$_FILES['up_picture']['size]: 


} 
yelse{ 
echo "上 传 文件 ".$_FILES[up_pictute][mame']." 不 合法 ! “: 
| 
} 
} 


?> 
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如 果 应 用 $_FILES['picture']['error] 对 上 传 文件 的 信息 进行 判断 ， 当 其 返回 值 为 2 时 , 说 明 上 传 文件 的 大 小 超 
出 了 表单 中 约定 的 范围 ， 而 表单 中 的 这 个 约定 值 是 通过 隐藏 域 MAX_FILE_SIZE 的 值 来 控制 的 。 在 设置 这 个 隐 


藏 域 时 ， 必 须 将 其 放置 在 文件 域 之 前 ， 否 则 不 起 作用 。 
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实例 225 


力 实例 说 明 


在 网 站 开发 的 过 程 中 ， 为 了 确保 充分 地 利用 服务 器 的 空间 ， 在 开发 上 传 功 能 时 最 好 能 够 对 上 传 文件 的 大 小 
进行 控制 。 本 实例 开发 的 上 传 功能 就 可 以 对 上 传 文件 的 大 小 进行 控制 。 如 果 上 传 文件 的 大 小 超过 指定 范围 ， 那 
么 将 给 出 提示 信息 ， 并 终止 上 传 。 运 行 效果 如 图 4.3 所 示 。 


一 个 战 TA 


记 反 上传 文件 : end_Franevork_7H. cx 


上 传 图 片 大 小 为 《 28 


上 传 错误 :上 传 文件 大 小 超出 配置 文件 规定 值 
Cepyright @ 1999-2010 吉林 省 明日 科技 有 限 公司 


4.3 限制 上 传 文件 的 大 小 


图 关键 技术 


控制 上 传 文件 的 大 小 有 两 个 关键 点 : 一 是 PHP 的 配置 文件 php.ini 对 上 传 文件 的 控制 , 如 果 上 传 文件 的 大 小 
超过 其 指定 的 范围 , 那么 上 传 就 会 失败 ; 二 是 在 PHP 配置 文件 允许 的 范围 内 , 在 程序 中 对 上 传 文件 大 小 的 控制 。 
(1) 在 PHP 中 ， 通 过 php.ini 文件 对 上 传 文件 进行 控制 ， 包 括 是 否 支持 上 传 、 上 传 文件 的 临时 目录 、 上 传 
文件 的 大 小 、 指 令 执行 的 时 间 、 指 令 分 配 的 内 存 空间 。 
在 php.ini 文件 中 ， 定 义 到 File Uploads 项 ， 完 成 对 上 传 相关 选项 的 设置 。 上 传 相关 选项 的 含义 如 下 : 
file_uploads: 如 果 值 是 on， 说 明 服 务 器 支持 文件 上 传 ; 如 果 为 off， 则 不 支持 。 一 般 默 认 是 支持 的 ， 
不 需 修改 。 
upload tmp_dir: 上 传 文件 的 临时 目录 。 在 文件 被 成 功 上 传 之 前 ， 首 先 存放 到 服务 器 端的 临时 目录 中 。 
多 数 使 用 系统 默认 目录 ， 但 是 也 可 以 自行 设置 。 
upload_max_filesize: 服务 器 允许 上 传 文件 的 最 大 值 ， 以 MB 为 单位 。 系 统 默认 为 2:MB， 如 果 网 站 需 
要 上 传 超过 2MB 的 数据 ， 那 么 就 要 修改 这 个 值 。 
上 述 是 php.ini 文件 的 File_ Uploads 项 中 与 上 传 相关 选项 参数 的 设置 说 明 , 除了 File Uploads 项 中 的 内 容 外 ， 
在 php.ini 文件 中 还 有 几 个 选项 会 影响 到 文件 的 上 传 。 
max_execution time: PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 秒 。 在 上 传 超大 文件 时 必须 修改 该 
选项 ， 否 则 即使 上 传 文件 在 服务 器 允许 的 范围 内 ， 若 是 超过 了 指令 所 能 执行 的 最 大 时 间 ， 仍 然 无 法 实 


现 上 传 。 
memory_limit: PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 MB， 其 大 小 同样 会 影响 到 超大 文件 的 
上 传 。 


(2) 在 客户 端 控 制 上 传 文件 ， 应 用 的 是 form 表单 中 的 enctype 和 method 属性 ， 以 及 隐藏 域 MAX_FILE_ 
SIZE。 
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enctype="multipart/form-data":， 指定 表单 编码 数据 方式 。 
method="post": 指定 数据 的 传输 方式 。 
<input type="hidden" name="MAX_ FILE_SIZE" value="10000" />: 通过 隐藏 域 控制 上 传 文件 的 大 小 ( 单 
位 为 字 节 ) ， 该 值 不 能 超过 php.ini 配置 文件 中 upload_max_filesize 选项 设置 的 值 。 它 不 能 完全 控制 上 
传 文件 的 大 小 ， 只 是 可 以 避免 一 些 不 必要 的 麻烦 。 

上 述 两 种 判断 的 结果 都 可 以 通过 全 局 变量 $_FILES 的 返回 值 来 体现 。$_FILES 是 一 个 数组 ， 包 含 所 有 上 传 
文件 的 信息 。 下 面 介 绍 $_FILES 数组 中 每 个 元 素 的 含义 ， 如 表 4.1 所 示 。 


表 4.1 $_FILES 数组 中 的 元 素 


因 办 办 


元 素 名 说 有明 
$ FILES[filename][name] 存储 上 传 文件 的 文件 名 ， 如 text.txt、title.jpg 等 
$ FILES[filename][size] 存储 文件 大 小 ， 单 位 为 字 节 
S$_FILES[filename][tmp name] 存储 文件 在 临时 目录 中 使 用 的 文件 名 。 因 为 文件 在 上 传 时 ， 首 先 要 将 其 以 临时 文件 的 身 
一 = 份 保 存在 临时 目录 中 
存储 上 传 文件 的 MIME 类 型 ，MIME 类 型 规定 各 种 文件 格式 的 类 型 。 每 种 MIME 类 型 都 
$_FILES[filename][type] 是 由 “/” 分 隔 的 主 类 型 和 子 类 型 组 成 ， 如 image/gif， 主 类 型 为 “图 像 ”， 子 类 型 为 GIF 


格式 的 文件 ，texvhtml 代表 文本 的 HTML 文件 

存储 与 文件 上 传 相关 的 错误 代码 。 此 项 目 是 PHP 4.2.0 版 本 中 新 增 的 内 容 ， 其 返回 值 有 
以 下 5 种 : 

0: 表示 没有 任何 错误 ， 文 件 上 传 成 功 

1: 表示 上 传 文件 的 大 小 超出 了 PHP 配置 文件 指令 upload_max_filesize 选项 限制 的 值 

2: 表示 上 传 文件 的 大 小 超出 了 HTML 表单 中 MAX_FILE_SIZE 选项 所 指定 的 值 

3: 表示 文件 只 被 上 传 了 一 部 分 

4: 表示 没有 上 传 任何 文件 


$_FILES[filename][error] 


图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 为 index.php 文件 添加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 使 
用 POST 方法 将 表单 中 数据 提交 到 本 页 。 

(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完成 图 片 的 上 传 ， 代 码 如 下 : 


< 


这 !empty($_FILES[up_picture][nameD)){ // 判 断 上 传 内 容 是 否 为 空 
if($_FILES['up_picture'][ error]>0){ // 判 断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 


switch($_FILES['up_picture']['error){ 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 


case 


2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 


Case 3: 
echo "上 传 文件 不 全 "; 
Ee 


和 
echo "没有 上 传 文件 "; 
break; 


} 
Jelse{ 
if(tis_dir("./upfile/"){ // 判 断 指 定 目录 是 否 存在 
mkdir("./upfile/"); // 创 建 目录 
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} 
Spath=./upfile/".time() .strstr($_FILES['up_picture][name],.); // 定 义 文件 名 称 和 存储 位 置 
iflis_uploaded file($_FILES[up_picture][tmp_namec])){ // 是 否 通过 HTTP POST 上 传 
if(!move_uploaded file($_FILES['up_picture'][‘tmp_name'].$path){ // 执 行 上 传 
echo "上 传 失败 ":; 
Jelse{ 


echo "文件 ".time0.$_FILES['up_picture][name']." 上 传 成 功 ， 大 小 为 :".$_FILES[wp_picture']['size']; 


Jelse{ 
echo "上 传 文件 "S_FILES[up_pictute][name] "不 合法 ! "; 
} 
} 
} 
> 


心 法 领悟 225: 如 何 上 传 超大 文件 。 
如 果 要 上 传 超 大 文件 ， 必 须 修改 php.ini 文件 。 修 改选 项 包括 : upload max filesize 的 最 大 值 、 
max_execution_time 一 个 指令 所 能 执行 的 最 大 时 间 和 memory_limit 一 个 指令 所 分 配 的 内 存 空 间 。 


起 味 指数 : 庚 友 庚 安 


图 实例 说 明 
在 开发 文件 上 传 功能 时 ， 不 仅 要 考虑 上 传 文件 的 大 小 ， 有 时 还 要 考虑 上 传 文件 的 类 型 ， 针 对 不 同 的 需要 对 
上 传 文件 的 类 型 加 以 限制 ， 这 里 指 的 文件 类 型 可 以 通过 文件 的 扩展 名 《如 .txt、.php、.doc) 来 判断 。 例 如 ， 在 
进行 文件 上 传 时 ， 涉 及 文本 说 明 性 文字 时 ， 最 好 将 上 传 的 文件 限制 为 以 “.txt” 为 后 绥 的 文本 格式 。 
运行 本 实例 ,如 图 4.4 所 示 ， 单 击 图 中 的 “浏览 ”按钮 选择 要 上 传 的 文件 (文件 不 是 以 “.txt” 为 扩展 名 》， 
单 击 “ 提 交 ” 按 钮 ， 程 序 将 给 出 错误 提示 。 


加 一 个 上 人 wins 


过 皇上 传 文件 : 「 vamppwampp_star 攻 有 HK 


上 傅 文 件 天 型 为 (tm) 


EED CE 


上 传 文件 类 型 不 正确 ? 


DA 
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图 4.4 限制 上 传 文件 的 类 型 


图 关键 技术 


文件 的 上 传 和 对 大 小 的 限制 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 只 讲解 限制 上 传 文件 类 型 的 关键 技术 ， 首 先 
要 通过 预定 义 全 局 变量 $_ FILES 中 的 $_FILES[files][name] 获 取 上 传 文件 的 名 称 ， 然 后 应 用 strstr0 函 数 截取 上 传 
文件 名 称 的 后 组， 最 后 判断 上 传 文件 的 后 缀 是 否 符合 要 求 。 


strstr0 函 数 的 语法 如 下 : 
string strstr(string strings, string needle); 
该 函数 用 于 在 字符 串 strings 中 查找 字符 串 needle 的 位 置 , 并 返回 从 needle 字符 串 开始 到 strings 字符 串 结束 
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的 所 有 内 容 ， 如 果 在 strings 中 没有 查找 到 needle， 该 函数 将 返回 FALSE。 


力 设计 过 程 
(1) 继续 使 用 实例 225 的 内 容 ， 在 其 基础 上 增加 对 上 传 文件 类 型 的 判断 ， 增 加 的 关键 代码 如 下 : 
<?php 
这 !empty($_FILES[up_picture][namec])){ // 潮 断 上 传 内 容 是 否 为 空 
S$type=$_FILES[up_picture[name']: /获取 上 传 文件 的 名 称 
$types=strstr($type 1/ 截取 上 传 文件 的 后 级 
if($types—".txt"){ // 判 断 上 传 文件 的 后 级 是 否 符合 要 求 
/省 略 了 部 分 代码 
} 
Yelse{ 
echo "上 传 文件 ".$_FILES['up_pictute"][name"]." 类 型 不 正确 ! "; 
} 
} 
?> 
(2) 重新 保存 index.php 文件 。 
图 秘笈 心 法 


心 法 领悟 226: 判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 。 

判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 ， 最 佳 的 方法 就 是 将 多 种 类 型 定义 到 一 个 数组 中 ， 然 后 通过 for 
循环 输出 数组 中 的 元 素 值 ， 将 输出 的 元 素 值 与 获取 的 文件 后 缀 进行 比较 ， 进 而 判断 其 是 否 符合 要 求 。 

EO , 

高 级 : 

趣味 指数 : 依依 食 依 家 


实例 227 | 


力 实例 说 明 


上 传 图 片 到 服务 器 ， 是 程序 开发 过 程 中 必 不 可 少 的 一 个 功能 。 它 不 但 可 以 达到 共享 图 片 的 目的 ， 而 且 可 
以 提高 网 站 的 访问 量 ， 丰 富 网 站 的 内 容 。 在 本 实例 中 将 讲解 如 何 通过 POST 方式 实现 多 图 片上 传 ， 运 行 结果 如 
图 4.5 所 示 。 


~ 一 个 此 起 wT 人 二 


多 文件 上 伟 ( 一 次 最 多 上 传 :个 图 片 》 


名 称 


流 晶 电视 
页 次 : 616 页 记录 : 54 条 分 页 : 首页 123436 尾 页 
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图 4.5 POST 方式 实现 多 图 片上 传 
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图 关键 技术 


多 文件 上 传 的 关键 是 如 何 定义 上 传 文件 元 素 的 名 称 及 判断 上 传 文件 的 数量 。 在 本 实例 中 ， 以 数组 的 形式 定 
义 上 传 文件 的 名 称 〈 上 传 文件 的 名 称 是 “files[]”) 。 为 了 达到 可 以 上 传 任意 数量 图 片 〈4 个 图 片 以 内 ) 的 目的 ， 
在 对 上 传 文件 进行 处 理 的 过 程 中 应 用 armray_filter0 函 数 和 回调 函数 去 除数 组 中 的 空 元 素 。 

array_filter() 函 数 ， 用 回调 函数 过 滤 数 组 中 的 单元 ， 语 法 如 下 : 

array array_filter ( array input [. callback callback] ) 

array_filter0 函 数 依次 将 input 数组 中 的 每 个 值 传递 到 callback0 函 数 。 如 果 callback0 函 数 返 回 TRUE， 则 
input 数组 的 当前 值 会 被 包含 在 返回 的 结果 数组 中 ， 并 且 数 组 的 键 名 保留 不 变 。 


上 上 说 明 : 在 回调 函数 中 不 要 对 数组 进行 修改 操作 ， 例 如 ， 增 加 或 者 删除 数组 中 的 元 素 ， 如 果 一 旦 数组 改变 ， 
那么 此 函数 的 运用 也 就 没有 意义 了 。 如 果 没 有 提供 callback0) 函 数 ，array_filter0) 函 数 将 删除 input 中 
所 有 等 值 为 FALSE 的 元 素 。 


本 实例 中 定义 的 回调 函数 是 check0)， 用 于 验证 数组 中 的 元 素 值 是 否 为 空 ， 其 语法 如 下 : 
function check($var) { /验证 数组 的 返回 值 是 否 为 空 
retum ($var {= ""); 


[al 说 明 : 通过 POST 方法 实现 多 图 片上 传 ， 在 创建 form 表单 时 ， 必 须 指定 enctype="multipart/form-data" 属 性 。 
如 果 要 通过 隐藏 域 MAX_FILE_SIZE 的 值 对 上 传 文件 的 大 小 进行 控制 ， 那 么 必须 将 隐藏 域 放置 在 上 
传 文件 的 文件 域 之 前 ， 否 则 是 不 会 起 作用 的 。 


力 设计 过 程 


(1) 创建 index.php 文件 。 添 加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 设置 enctype="multipart/ 
form-data"， 将 数据 提交 到 index_ok.php 页 ， 完 成 多 个 文件 的 上 传 操作 ， 其 关键 代码 如 下 : 


<table width="750" border="0" cellspacing="0" cellpadding="0"> 
<form action="index_ok.html" method="post" enctype="multipart/form-data" name="form1"> 
<tr> 
<td width="100" height="25" align="right" class="STYLE1"> 内 容 1: </td> 
<td width="150" align="center"><input name="files[]" type="text" id-"filles[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
<tr> 
<tr> 
<td height="25" align="right" class="STYLE1"> 内 容 2: </td> 
<td align="center"><input name="files[]" type="text" id="files[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
</tr> 
<tr> 
<td colspan="3" align="center"> 
<input type="image" name="imageFicld" src="images/bg_09jpg">&nbsp:&nbsp:&nbsp:&nbsp: 
<input type="image" name="imageField2" sre—"images/bg 11.jpg"></td> 


(2) 在 index.php 文件 中 ， 连 接 数 据 库 ， 读 取 数据 库 中 存储 的 数据 ， 实 现 上 传 文件 的 分 页 输出 。 代 码 请 参 
考 光盘 中 的 相关 内 容 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 多 个 文件 存储 到 服务 器 中 ， 将 文件 的 名 称 和 存储 
路 径 存储 到 数据 库 中 ， 其 代码 如 下 : 
2 ( "Content-type: text/html; charset=UTF-8" ): // 设 置 文件 编码 格式 
include "conn/conn.php": // 包 含 数据 库 链接 文件 
if($_POST [files] = "") { 
if(lis dir ("./upfile" )) { 
mkdir ("Jupfile" ): // 创 建 上 传 文件 存储 文件 夹 
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} 


$data = date ( "Y-m-d H:m:s" ); /定义 时 间 

function check(Svan) { /验证 数组 的 返回 值 是 否 为 空 
retum ($var {= ""); // 如 果 不 为 空 ， 则 返回 数组 元 素 

} 

$files = array_filter ( $_POST ["files"], "check" ); /去 除数 组 中 的 空 值 

Sarray = array_filter ($_FILES ["picture"] ["name"], "check" ); /去 除数 组 中 的 空 值 

foreach ( $array as Skey => $value ) { 1/ 循环 读 取 数组 中 的 数据 
Spath = upfile/ . time 0 . $key . strtolower ( strstr ( $value, "." ) ); /定义 上 传 文件 存储 位 置 


move_uploaded_file ($_FILES ["picture"] ["tmp_name"] [Skey]. $path ): /执行 上 传 操作 
Squery = "insert into tb_up_file (file_test.data,file_name) values (‘$path','$data','$files[Skey])"; 
Sresult = mysql_query ( $query ); 
echo "<script>alert(' 图 片上 传 成 功 ); window.location href='index.html';</script>"; 


} 
> 


国 秘笈 心 法 
心 法 领悟 227: 通过 伪 静 态 技术 隐藏 PHP 文件 后 缀 。 
首先 ， 修 改 Apache 服务 器 的 配置 文件 httpd.conf。 打 开 httpd.conf 文件 ， 定 位 到 如 下 位 置 : 


| 
将 该 项 前 面 的 “#” 去 掉 后 启动 该 项 。 
然后 , 查找 httpd.conf 文件 , 找到 其 中 的 AllowOverride 项 , 将 它 的 值 都 修改 为 All。 保存 并 重新 启动 Apache 
kt 使 修改 生效 。 
A htaccess 文件 ， 实 现 对 PHP 文件 后 缀 的 隐藏 操作 。.htaccess 文件 的 代码 如 下 : 


报 后 在 On # 启 动 

RewriteRule index.html$ 

RewriteRule ‘index_ok.html$ index_ok.php 

RewriteRule ^index-([0-9]+)-([0-9}+)-([0-9}+)\html$ indexphp?vv=Sl&liil-S2&page=S3 [L] 


通过 正则 表达 式 对 文件 的 后 缀 和 传递 的 参数 进行 匹配 ， 完 成 对 PHP 文件 后 缀 的 隐藏 操作 。 


4.2 文件 下 载 


全 | 


力 实例 说 明 


在 一 个 完整 的 网 站 中 ， 具 有 文件 下 载 功能 能 够 给 网 站 带 来 更 多 的 访问 者 ， 增 加 网 站 的 访问 量 。 最 常用 的 文 
件 下 载 方式 就 是 通过 链接 下 载 。 在 本 实例 中 ， 应 用 链接 方式 进行 下 载 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 弹出 文 
件 “ 另 存 为 ”对 话 框 ， 完 成 下 载 保存 操作 ， 运 行 结果 如 图 4.6 所 示 。 


4.6 链接 方式 的 文件 下 载 
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图 关键 技术 


本 实例 主要 通过 超 链接 来 实现 文件 的 下 载 。 通 过 select 语句 从 数据 库 中 读 取 文件 存储 的 路 径 ， 然 后 将 该 文 
件 作 一 个 超 链 接 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 下 载 该 文件 。 


力 设计 过 程 
(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 名 称 创建 超 链接 ， 完 成 图 片 的 下 载 操作 ， 其 关键 代码 如 下 : 


<a href="<?php echo Smyrow[file_test]:?>"><?php echo $myrow[file name]:?></a> 
(2) 保存 对 文件 的 修改 ， 运 行程 序 ， 运 行 结果 参看 实例 说 明 。 


心 法 领悟 228: 不 同类 型 的 文件 ， 下 载 操作 不 同 。 
如 果 是 压缩 的 文件 ， 可 以 直接 下 载 ， 如 果 不 是 ， 则 需要 右 击 ， 然 后 在 弹出 的 快捷 菜单 中 选择 “另存 为 ”命令 。 


Ce 
A 进行 下 载 中 级 | 
起 味 指数 : 裕 契 亦 容 


力 实例 说 明 


除了 可 以 通过 链接 方式 下 载 文件 之 外 ， 还 可 以 通过 header0 函 数 完成 下 载 操 作 。 例 如 ， 本 实例 中 就 是 应 用 
header0 函 数 实现 文件 的 下 载 ， 如 果 下 载 的 文件 不 存在 ， 则 会 给 出 提示 信息 ， 运 行 结果 如 图 4.7 所 示 。 


您 起 打开 或 保存 此 文件 吗 ? 


名 称 : 12759792140.png 
类 型 PNG 图 像 , 1.95 KB 
发 送 者 : 127.0.0.1 


打开 @) | _ 保存 &) | [区 汪汪 
© 各 


图 4.7 应 用 header0 函 数 实现 文件 下 载 


力 关键 技术 


通过 HTTP 方式 下 载 文件 ， 主 要 应 用 header() 函 数 。 

headerO 函 数 属 于 HITP 函数 , 其 作用 是 以 HITP 协议 将 HTML 文档 的 标 头 送 到 浏览 器 , 并 告诉 浏览 器 具体 
怎么 处 理 这 个 页 面 。header0 函 数 的 语法 如 下 : 

void header ( string string [, bool replace [. int http_response_code]] ) 

参数 说 明 : 

string: 发 送 的 标 头 。 

replace: 如 果 一 次 发 送 多 个 标 头 ， 对 于 相似 的 标 头 是 蔡 换 还 是 添加 。 如 果 是 FALSE， 则 强制 发 送 多 个 同类 
型 的 标 头 。 默 认 是 TRUE， 即 蔡 换 。 

http_response_code: 强制 HITP 响应 为 指定 值 。 
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通过 HTTP 下 载 的 代码 如 下 : 


header("Content-type: application/x-gzip"): 
header("Content-Disposition: attachment': filename= 文 件 名 "): 

header("Content-Description: PHP3 Generated Data"); > 

HTTP 标 头 有 很 多 ， 这 里 介绍 的 是 下 载 的 HTTP 标 头 ， 其 代码 如 下 : 
header('Content-Disposition: attachment: filename="filename"); 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 flename， 即 将 filename 蔡 换 为 要 下 载 的 文件 。 
设计 过 程 
(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 创建 超 链接 ， 链 接 到 download.php 文件 ， 通 过 download.php 完 
成 文件 的 下 载 操作 。 在 index.php 文件 中 所 做 的 修改 如 下 : 


<td width="245" height="100" align="center" valign="middle" bgcolor="#FOFOF0"><a href="download-<?php echo $myrow[file_test]:?>.html" title=" 
点 击 即 可 下 载 ! "><?php echo "<img sre=\"$myrow[file_test]\" width=\"250\" height=\"100\W border=\"0W>"?></a></td> 


(2) 创建 download.php 文件 ， 应 用 header0 函 数 实现 文件 的 下 载 ， 其 代码 如 下 : 


<2php 
header("Content-type: text/html: charset=UTF-8"); // 设 置 文件 编码 格式 
Spath = $_GET['path"]; /获取 文件 路 径 
if(!empty($path) and !is_null($path)){ 1/ 判断 变量 是 否 为 空 ， 是 否 为 NULL 
$filename=basename($path); /获取 文件 名 
$file=@fopen($path,"r"); 
if($file){ 
header("Content-type:application/octet-stream"); /输出 MIME 类 型 
header("Accept-ranges:bytes"); // 接 受 的 范围 单位 
header("Accept-length:".filesize($path)); /文件 长 度 
header("Content-Disposition:attachment;filename=".$filename); 。 ”// 默 认 的 文件 保存 对 话 框 中 的 文件 名 称 
echo fread($file, filesize($path)); // 读 取 文 件 
felose($file); /| 关闭 文件 
exit; /退出 
jslse{ 
echo "<script>alert(' 您 下 载 的 文件 不 存在 ! '); history.backO:;</script>": 
} 
} 
> 


国 秘笈 心 法 
心 法 领悟 229: headerO 函 数 的 应 用 。 
通过 headerO 函 数 不 但 可 以 实现 文件 的 下 载 ， 还 可 以 实现 以 下 3 个 功能 : 
(1) 重 定向 ， 这 是 最 常用 的 功能 。 


header("Location: http://www.mrbeed.com"): 


(2) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 而 不 是 使 用 存在 于 客户 端的 缓存 。 
/设置 页 面 的 过 期 时 间 (用 格林 威 治 时 间 表示 ) 
header("Expires: Mon. 08 Jul 2008 08:08:08 GMT"): 
// 设 置 页 面 的 最 后 更 新 日 期 (用 格林 威 治 时 间 表示 ) ， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: " . gmdate("D., dM Y Hii:s") . "GMT"): 


header("Cache-Control: no-cache, .must-revalidate"): /控制 页 面 不 使 用 缓存 

header("Pragma: no-cache"): /参数 〈 与 以 前 的 服务 器 兼容 ) ， 即 兼容 HTTP 1.0 协议 
header("Content-type: application/file"): /输出 MIME 类 型 

header("Content-Length: 。 227685"): /文件 长 度 

header("Accept-Ranges: 。 bytes"): /接受 的 范围 单位 

// 上 默认 的 文件 保存 对 话 框 中 的 文件 名 称 

header("Content 一 Disposition: attachment: filename=$filename"): // 实 现下 载 


(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
header(HTTP/1.1 401 Unauthorized"): 
header('status: 401 Unauthorized’); 
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实例 230 


力 实例 说 明 


在 开发 网 站 的 过 程 中 ， 很 多 的 服务 条 款 、 协 议 等 都 是 以 文本 文件 的 形式 存储 的 。 如 果 要 读 取 这 些 文件 中 的 


内 容 ， 就 需要 应 用 到 文件 系统 函数 。 在 本 实例 中 将 介绍 如 何 通过 文件 系统 函数 读 取 整 个 文件 的 内 容 ， 其 运行 效 
果 如 图 4.8 所 示 。 
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4.8 读 取 文本 文件 的 内 容 
力 关键 技术 


在 PHP 中 ， 读 取 整 个 文件 的 内 容 ， 有 3 个 函数 可 以 选择 : 
readfile() 函 数 


readfile() 函 数 读 取 一 个 文件 并 将 其 写 入 输出 缓冲 ， 如 成 功 ， 返 回 读 取 的 字 节 数 ， 如 失败 ， 返 回 FALSE， 
语法 如 下 : 

intreadfile ( string filename [, bool use_include_path [, resource context] ) 

参数 flename 指定 读 取 的 文件 名 称 ， 参 数 use_include_path 控制 是 否 支 持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设置 为 TRUE; 参数 context 是 PHP 5.0 的 新 增 内 容 。 
[ED 说 明 : 应 用 readfile0 函 数 时 ， 不 需要 打开 /关闭 文件 和 输出 语句 ， 直 接应 用 即 可 。 

fneO 函 数 


file0 函 数 将 整个 文件 的 内 容 读 入 一 个 数组 中 。 如 成 功 ， 返 回 数组 ， 数 组 中 的 每 个 元 素 都 是 文件 中 对 应 的 一 
行 ， 包 括 换行 符 在 内 ， 如 失败 ， 返 回 FALSE。 语 法 如 下 : 


array file ( string filename [, int use_include path [, resource context]] ) 
其 参数 与 readfile0 函 数 相 同 ， 唯 一 区 别 是 该 函数 的 返回 值 是 数组 。 
回 file_get_contents0 函 数 


人 le_get_contents0 函 数 将 文件 内 容 读 入 一 个 字符 串 。 如 果 有 offset 和 maxlen 参数 ,将 在 参数 offset 所 指定 的 


二 | 
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位 置 开始 读 取 长 度 为 maxlen 的 内 容 。 如 果 失 败 ， 返 回 FALSE。 语 法 如 下 : 
string file_get_contents ( string filename [. bool use_include_path [. resource context [, int offset [, int maxlen]]]] ) 
参数 filename 指定 读 取 的 文件 名 称 ; 参数 use_include_path 控制 是 否 支持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设 置 为 TRUE。 


图 设计 过 程 
(1) 创建 index.php 文件 。 


(2) 在 index.php 文件 中 分 别 应 用 fle0 和 file_get contents0 函 数 读 取 文 本 文件 中 的 内 容 ， 其 关键 代码 如 下 : 
<!-- 使 用 他 e0 函 数 读 取 count.txt 文件 的 内 容 -> 


<?php 
Sarr = 人 ile(testltxty; 
foreach ($arr as $value) { 
echo iconv("gb2312", "utf-8", $value) . "<br>"; 
} 
?> 
<!-- 使 用 fle_get_contents0 函 数 读 取 count.txt 文件 的 内 容 --> 


?php 
S$str = file_get_contents('test2.txt); 
echo iconv("gb2312", "utf-8", $str); 
?> 


图 秘笈 心 ; 

心 法 领悟 230: 读 取 整 个 文件 的 特性 。 

在 通过 readfile0、file0 和 file_get_contents0 函 数 读 取 整个 文件 中 的 内 容 时 ， 不 需要 通过 fopen() 函 数 打 开 文 
件 ， 也 不 需要 使 用 felose0 函 数 关闭 文件 。 

但 是 ,在 读 取 一 个 字符 、 一 行 字符 和 任意 长 度 的 字符 串 时 ， 必 须 应 用 fopen0 函 数 打开 文件 后 才能 进行 读 取 ， 
在 读 取 完 成 后 还 要 应 用 fcloseO 函 数 关闭 文件 。 


ge 
图 实例 说 明 


在 遍历 文件 中 的 内 容 时 ， 由 于 文件 内 容 很 多 ， 最 理想 的 方法 就 是 分 页 读 取 文 本 文件 中 的 内 容 。 本 实例 将 介 
绍 如 何 分 页 读 取 文本 文件 中 的 数据 ， 其 运行 结果 如 图 4.9 所 示 。 


| 诗句 评价 


“死生 到 岗 。 


4.9 文本 文件 的 分 页 读 取 
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图 关键 技术 


完成 超 长 文本 的 分 页 输出 需要 3 方面 的 技术 : 第 一 个 方面 ， 自 定义 函数 。 通 过 自 定义 函数 读 取 文本 文件 ， 
可 以 避免 中 文字 符 串 出 现 乱码 ; 第 二 个 方面 , 字符 串 函 数 。 需要 通过 strlen0 函 数 计算 字符 串 的 长 度 , 通过 substr0 
函数 对 字符 串 进行 截取 ;第 三 个 方面 ， 文 件 系统 函数 。 通 过 file_get_contents0) 函 数 读 取 文本 文件 中 的 数据 。 


自 定义 函数 msubstr0 的 语法 如 下 : 
// 定 义 一 个 用 于 截取 一 段 字符 串 的 函数 msubstr0 
function msubstr($str,Sstart.Slen){ /Sstr 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 是 长 度 
S$strlen=$start+ $len; // 用 $strlen 存储 字符 串 的 总 长 度 〔 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i=0;$i<$strlen;$i++){ // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
iford(substr($str,$i,1))>0xa0){ // 如 果 字 符 串 中 首 个 字 节 的 ASCI 序数 值 大 于 0xa0， 则 表示 为 汉字 
Stmpstr.=substr($str, $1.2); /| 每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 
Bis /变量 自 加 1 
jelse{ // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
Stmpstr.=substr($str,$i,1); 
¥ 
} 
retum $tmpstr; /| 输出 字符 串 


了 
图 设计 过 程 
(1) 创建 function.php 文件 ， 编 写 自 定义 函数 msubstr0， 完 成 对 文本 文件 的 截取 操作 。 


(2) 创建 index.php 文件 ， 首 先 通过 文件 系统 函数 fle_get_ contents0 读 取 整 个 文件 的 内 容 ， 然 后 调用 自 定 
义 函数 和 字符 串 函数 完成 对 文件 的 截取 操作 ， 实 现 截取 后 内 容 的 分 页 输出 ， 其 关键 代码 如 下 : 


<div id="synopsis'> 
<!-- 创 建 div 标签 ， 用 于 获取 js 文件 中 返回 的 分 页 结果 --> 
<table width="545" border="0" cellspacing="0" cellpadding="0"> 
<t> 


<td><?php 
include("function.php"): 
// 读 取 超 长 文本 中 的 数据 ， 实 现 超 长 文本 中 数据 的 分 页 显示 
if($_GET['page ){ 
S$counter=file_get_contents("data.txt"); 
Slength=strlen($counter); 
S$page count=ceil($length/850); 
$c=msubstr($counter,0.($_GET['page']-1)*850); 
$cl=msubstr($counter,0,$_GET['page']*850); 
echo substr($cl,strlen($cj,strlen(Scl)-sttlen(Sc)); 
} 


> 
<htd> 
</t> 
<tr> 
<td><table width="535" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<!-- 设 置 超 长 文本 分 页 显示 的 超 链 接 --> 
<td width="37%" align="center" valign="middle" bgcolor="#FFFFFF"> 内 容 &nbsp:<?php echo $page_count:?> 页 
&nbsp:&nbsp: 当 前 &nbsp: 第 <?php echo $S_GET[page]:?> 页 </td> 
<td width="63%" height="28" align="center" valign="middle" bgcolor="#FFFFFF"><?php 
if($_GET[page]!=D{ 


<!-- 调 用 no_refurbish_pagination0 函 数 ， 实 现 无 刷新 的 分 页 输出 --> 
<a href="#" onClick='return no_refurbish_pagination("index_ok.php?page=1")> 首 页 </a>&nbsp: <a href="#" 
onClick='return no_refurbish_pagination("index_ok php?page=<?php echo $_GET[page']-1:?>")> 上 一 页 </a> 
php } 
这 $_GET[page]<$page_count){ 


<a href="#" onClick="return no_refurbish pagination(index_ok.php?page=<?php echo $_GET[page]+1:?>)"> 下 一 
页 </a> <a href="#" onClick='retumn no_refurbish_pagination("index_ok.php?page=<?php echo $page_count:?>")> 尾 页 </a> 
Iphp 


?> 


Ye 
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} 
> 
<itd> 
</tr> 
</table></td> 
</> 
</table> 


</div> 
(3) 创建 index_ok.php 文件 ， 实 现 数 据 的 无 刷新 分 页 。index_ok.php 中 的 内 容 与 index.php 中 <div> 标 签 
synopsis 的 内 容 相同 。 
(4) 创建 js 脚本 文件 discuss_jsjs， 通 过 AJAX 实现 无 刷新 的 操作 。 


图 秘笈 心 法 
心 法 领悟 231: AJAX 无 刷新 分 页 。 


在 本 实例 中 不 但 实现 了 文本 文件 内 容 的 分 页 输出 ， 而 且 是 无 刷新 分 页 输出 。 具 体操 作 通过 JS 脚本 文件 
discuss_js.js 和 index_ok.php 完成 。 


44 文件 操作 
wei 


力 实例 说 明 


为 了 便于 对 网 站 进行 管理 、 维 护 和 更 新 ， 应 该 设计 一 个 能 够 对 文件 进行 操作 的 模块 ， 实 现 对 文件 的 创建 、 
复制 、 移 动 和 删除 等 操作 ， 这 样 能 够 给 网 站 的 管理 工作 提供 很 大 方便 ， 不 再 因为 要 修改 某 个 文件 而 登录 到 FTP 
中 、 通 过 下 载 或 上 传 实现 文件 的 更 新 ， 从 而 节省 很 多 时 间 。 运 行 本 实例 ， 实 现 对 指定 文件 的 创建 、 复 制 、 移 动 
和 删除 操作 。 只 要 在 文本 框 中 输入 要 复制 文件 的 路 径 和 名 称 ， 在 对 应 的 文本 框 中 输入 指定 文件 要 复制 到 的 具体 
文件 夹 的 路 径 和 名 称 〈 包 括 指定 文件 的 名 称 ) ， 然 后 单 击 “提交 ”按钮 即 可 ， 运 行 结果 如 图 4.10 所 示 。 
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图 4.10 文件 操作 汇总 


图 关键 技术 
本 实例 主要 应 用 fopen0、copy0、rename0 和 unlink0 这 4 个 函数 完成 文件 的 创建 、 复 制 、 移 动 和 删除 操作 。 
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fopen0 函 数 用 于 打开 文件 或 者 URL， 其 语法 如 下 : 
ER 
创建 文件 主要 应 用 fopen0 函 数 的 mode 参数 ，mode 参数 的 可 选 值 如 下 : 
回 'w' 写 入 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 0。 如果 文 件 不 存在 ， 则 进行 创建 。 
回 "w+' 读 写 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 0。 如 果 文 件 不 存在 ， 则 进行 创建 。 
回 'a' 写 入 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 
回 ”'at' 读 写 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 


上 说 明 : 上 述 4 种 方式 都 可 以 完成 文件 的 创建 操作 ， 前 提 是 指定 路 径 下 不 存在 被 创建 的 文件 。 
copy0 函 数 主要 用 于 复制 文件 ， 其 语法 如 下 : 


ER 

本 函数 将 文件 从 source 复制 到 dest， 如 果 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 
rename() 函 数 主要 用 于 文件 重 命 名 ， 其 语法 如 下 : 

er 

本 函数 将 oldname 重 命名 为 newname， 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE。 


[9 说 明 : ename() 函 数 不 但 可 以 给 文件 重 命名 ， 当 将 指定 的 文件 移动 到 另外 一 个 路 径 下 的 文件 天 中 时 ， 不 改变 
该 文件 的 名 称 ， 即 可 实现 对 指定 文件 的 移动 操作 。 


unlink() 函 数 主要 用 于 删除 文件 ， 其 语法 如 下 : 


bool unlink(string filename); 

该 函数 用 于 删除 文件 ， 如 果 删 除 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
力 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 设 计 文件 汇总 的 页 面 。 然 后 应 用 switch 语句 设计 一 个 简单 的 框架 ， 完 成 
复制 、 移 动 、 创 建 和 删除 操作 之 间 的 切换 。 最 后 ， 编 写 PHP 脚本 ， 根 据 表单 中 提交 的 数据 ， 执 行 不 同 的 文件 操 
作 ， 其 关键 代码 如 下 : 


<?php 
switch ($_GET [operate] { 
case "found" : 


include ("found php"); 
break: 


本 
include ("copy.php"); 
break: 

Case "move" : 

include ("move.php"); 

break:; 

case "delete" : 

include ("delete.php"); 
break:; 


default : 
include ("copy.php"); 
} 


> 


<?php 
让 ($_POST [Submit] 一 "复制 ") { 
Scopy = iconv ( "utf-8", "gb2312", $_POST [copys] ): 
Scopys2 = iconv ( "utf-8", "gb2312", $_POST ['copys2] ): 
if(copy ($copy, $copys2 )) { 
echo "<script>alert( 复 制 成 功 !1);</script>"; 
} else { 
echo "<script>alert( 复 制 失败 !1):</script>"; 
} 


301 


PHP 开发 实例 大 全 (基础 卷 ) 
/省 略 了 部 分 代码 
?> 


(2) 分 别 创建 copyphp、deletephp、foundphp 和 movephp 文件 ， 完 成 不 同 操作 的 执行 页 面 。copy.php 文 
件 的 代码 如 下 : 
<table width="466" height="112" border="0" cellpadding="0" cellspacing="0"> 
<form name="form1" method="post" action=""> 
<t> 
<td width="111" rowspan="2" align="center"> 复 制 文件 <td> 
<td width="67" align="right" valign="bottom">copy: </td> 
<td width="229" height="39" valign="bottom"><input name="copys”" 
type="text" id="copys" size="22"></td> 
<td width="126" rowspan="2" align="left" valign="middle"><input 
type="submit" name="Submit" value=" 复 制 "></td> 
</lt> 
<t> 
<td align="right" valign="top">affix: </td> 
<td height="41" valign="top"><input name="copys2" type="text" 
id="copys2" size="22"></td> 


<td colspan="4" align="center"> 例 如 : F:\xampp\htdocs\MR\05\012\test.txt</td> 


图 秘笈 心 ; 


心 法 领悟 232: 编码 格式 转换 的 必要 性 。 

在 应 用 文件 操作 函数 执行 文件 的 创建 、 移 动 、 复 制 和 删除 操作 时 ， 由 于 实例 的 页 面 编码 格式 是 UTF-8， 所 
以 从 表单 中 获取 的 元 素 值 不 能 直接 应 用 到 文件 操作 函数 中 ， 必 须 对 其 进行 编码 转换 ， 由 UTF-8 编码 转换 为 
GB2312 编码 ， 否 则 文件 操作 函数 不 能 正确 地 执行 。 


力 实例 说 明 


对 目录 、 文 件 的 操作 不 应 该 是 盲目 的 ， 应 该 首先 确定 其 是 否 存 在 ， 如 果 存 在 才能 对 它 执行 各 种 操作 ， 否 则 
是 没有 任何 意义 的 。 相 反 ， 有 些 操作 必须 是 在 指定 的 目录 、 文 件 不 存在 的 情况 下 进行 的 。 此 时 必须 有 一 个 方法 
能 够 对 目录 、 文 件 进行 定位 ， 确 定 它 是 否 存在 ， 这 就 是 本 实例 将 要 讲解 的 内 容 。 运 行 本 实例 ， 在 文本 框 中 输入 
目录 、 文 件 的 完整 路 径 ， 单 击 “提交 ”按钮 ， 运 行 结 果 如 图 4.11 所 示 。 


文件 名 称 : [FE WPpSewwwWMRO4O14 提交 


请 辆 入 正确 的 目录 、 文件 路 径 b 


和 1 CepyBiahts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.11 目录 、 文 件 定位 器 
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[上 说 明 : 本 实例 实现 的 功能 虽然 非常 简单 ， 但 是 这 个 方法 在 很 多 程序 中 都 会 被 用 到 ， 只 是 表现 的 方式 不 同 。 


图 关键 技术 


PHP 中 判断 指定 的 目录 、 文 件 是 否 存在 ， 应 用 的 是 file_exists0 函 数 ， 该 函数 的 语法 如 下 : 
int file_exists(string filename); 
该 函数 用 来 检测 目录 、 文 件 是 否 存 在 ， 如 果 存 在 返回 TRUE， 否 则 返回 FALSE。 
(aa 说 明 : 要 在 Windows 下 检查 网 络 中 的 共享 文件 应 该 使 用 //computername/share/filename 或 者 \computername\ 
share\filename。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
(2) 添加 表单 ， 设 置 文 本 框 ， 提 交 目 录 、 文 件 的 完整 路 径 ， 并 设置 提交 按钮 。 
(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 目录 、 文 件 路 径 。 首 先 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 
后 应 用 fe_exists() 函 数 判 断 指定 的 目录 、 文 件 是 否 存 在 ， 其 关键 代码 如 下 : 
党 POST [file name] ="") { 
Sfile name =iconv ( "utf-8", "gb2312", $ POST ['file name']); 
if (file_exists ( $file_name )) { 
echo "<script>alert(' 目 录 、 文 件 已 定位 ! :</script>"; 
else 
: 于 文件 不 存在 ! :</script>"; 
J 人 "<script>alert(' 请 输入 正确 的 目录 、 文 件 路 径 ! ;</script>"; 
} 


> 
图 秘笈 心 ; 
心 法 领悟 233，UTF-8 编码 格式 对 中 文字 符 串 的 影响 。 
在 本 实例 中 , 由 于 使 用 的 是 UTF-8 编码 格式 , 因此 当 提 交 的 目录 、 文 件 路 径 中 存在 中 文字 符 串 时 , file_exists() 


函数 就 不 能 正确 地 判断 目录 、 文 件 是 否 存在 。 只 有 将 UTF-8 编码 格式 的 元 素 值 转换 为 GB2312 编码 格式 之 后 ， 
file_exists0 函 数 才能 对 中 文字 符 串 的 目录 、 文 件 路 径 作 出 正确 的 判断 。 


: Ce i 
力 实例 说 明 


在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 经 常会 修改 文件 的 名 称 。 本 实例 将 介绍 一 种 修改 文件 名 称 的 方法 。 运 
行 本 实例 ， 在 “原文 件 名称 ” 文 本 框 中 输入 原始 文件 的 存储 路 径 和 文件 名 ， 在 “新 文件 名 称 ”文本 框 中 输入 新 
文件 的 路 径 和 文件 名 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.12 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


原文 伯 各 各 : [FApOSeWWWWNROIAOISWVAGESSE 


提交 
得 症 6 称 : FSeVwwwAMROADINIMAGESVestT | 
C2 


An copy 和 ts © reserred 20:0 青 村 省 明科 技 有 限 公司 


图 4.12 修改 文件 名 


力 关键 技术 

文件 重 命名 应 用 的 是 rename0 函 数 ， 不 过 首先 要 应 用 file_exists0 函 数 判断 该 文件 是 否 存在 ， 如 果 存在 则 应 
用 rename0 函 数 对 该 文件 进行 重 命名 ， 和 否则 给 出 提示 信息 。 
图 设计 过 程 

(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 

(2) 添加 表单 ， 设 置 两 个 文本 框 ， 提 交 文 件 的 原始 名 称 和 新 名 称 ， 并 设置 提交 按钮 。 

(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 元 素 值 。 由 于 网 页 使 用 的 是 UTF-8 编码 ， 所 以 为 了 避免 在 获取 中 


文字 符 串 时 出 现 乱码 ， 应 先 用 iconv0 函 数 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 后 应 用 fe_exists0 函 数 判断 
指定 的 文件 是 否 存 在 ， 如 果 存 在 则 应 用 rename0 函 数 对 其 进行 重新 命名 ， 其 关键 代码 如 下 : 


<?php 
这 ($_POST['Submit] 一 "提交 ") { 
Sold_name=iconv("utf-8","gb2312",$_POST['old_name’]); // 获 取 表单 元 素 ， 并 进行 编码 格式 转换 
Snew_name=iconv("utf-8"."gb2312",$_POST['new_name']); // 获 取 表单 元 素 ， 并 进行 编码 格式 转换 
if (file_exists ( $old_name)) { 1/ 判断 文件 是 否 存在 
if(rename ( $old_name, Snew_name )) { /把 原文 件 重新 命名 
echo "修改 成 功 "; 
3 
}else{ 
print$_POST['old_name'] . "文件 不 存在 !<br>"; 
?> 
图 秘笈 心 法 


心 法 领悟 234: iconv0 函 数 在 转 码 过 程 中 的 重要 性 。 

如 果 程 序 设计 时 应 用 的 是 UTF-8 编码 ， 那 么 就 有 必要 了 解 iconv0 函 数 。 因 为 操作 系统 默认 使 用 的 是 简体 中 
文 《GB2312 编码 或 者 GBK 编码 ) ， 所 以 在 将 UTF-8 编码 格式 的 数据 应 用 到 默认 为 GB2312 编码 的 程序 中 时 ， 
难免 会 执行 失败 ,特别 是 涉及 中 文字 符 串 时 。 例 如 , 在 本 实例 中 , 如 果 直 接 将 获取 的 表单 元 素 值 应 用 到 file_existsO 
函数 或 者 rename0 〇 函数 中 ， 就 会 出 现 乱 码 。 


实例 235 浊 趣味 指数 : 廊 塘 去 家 


力 实例 说 明 


如 果 说 判断 目录 、 文 件 是 否 存在 是 对 目录 、 文 件 进行 操作 的 前 提 条 件 ， 那 么 获取 文件 属性 则 是 对 文件 进行 


第 4 章 文件 操作 


操作 的 必要 条 件 。 因 为 在 执行 一 些 特殊 的 操作 之 前 ， 必 须 对 文件 的 类 型 、 大 小 或 者 修改 时 间 进行 判断 。 在 本 实 
例 中 ， 将 介绍 如 何 获 取 文 件 的 类 型 、 大 小 和 修改 时 间 。 运 行 本 实例 ， 在 文本 框 中 输入 正确 的 目录 或 者 文件 的 路 
径 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.13 所 示 。 


文件 名 称 : |F:VAppSerWwwwiMRWD4WD15\index.php 提交 


请 给 入 正确 的 目录 、 文 件 路 征 ? 


文件 类 型 : fle 
文件 大 小 : 2403 字 节 
修改 时 间 ; 2010.07.030524.56 
An FopyRieht< © reserwea pnin 古林 省 明月 科技 有 限 公司 


图 4.13 文件 属性 分 析 


力 关键 技术 


在 PHP 中 ， 获 取 文 件 类 型 使 用 filetype0 函 数 ， 获 取 文件 大 小 使 用 filesize0 函 数 ， 而 获取 修改 时 间 使 用 
filemtime() 函 数 。 
filetype() 函 数 用 于 获取 文件 类 型 ， 其 语法 如 下 : 


string filetype ( string filename ) 
该 函数 返回 文件 的 类 型 ， 类 型 值 包括 fifo、char、dir、block、link、file 和 unknown。 如 果 出 错 则 返回 FALSE。 
filesize() 函 数 用 于 获取 文件 大 小 ， 其 语法 如 下 : 


int filesize ( string filename ) 


该 函数 返回 文件 大 小 的 字 节 数 ， 如 果 出 错 返回 FALSE 《在 错误 报告 级 别 为 E WARNING 的 情况 下 ) 。 


| 说 明 : 因为 PHP 的 整数 类 型 是 有 符号 的 ， 并 且 大 多 数 平台 使 用 32 位 整数 ，filesize() 函数 在 碰 到 大 于 2GB 
的 文件 时 可 能 会 返回 非 预 期 的 结果 。 对 于 2GB~4GB 之 间 的 文件 通常 可 以 使 用 sprintf("%u"， 
filesize($file)) 来 克服 此 问题 。 
filemtime0 函 数 用 于 获取 文件 修改 时 间 ， 其 语法 如 下 : 


ER 
该 函数 返回 文件 上 次 被 修改 的 时 间 ， 出 错时 返回 FALSE。 时 间 以 UNIX 时间 戳 的 方式 返回 ， 可 用 于 date0 函 数 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
(2) 添加 表单 ， 设 置 目录 、 文 件 提交 的 文本 框 ， 提 交 目 录 或 者 文件 的 路 径 ， 并 设置 提交 按钮 。 
(3) 编写 PHP 脚本 , 获取 表单 中 提交 的 元 素 值 。 首先 , 判断 提交 的 值 是 否 为 空 , 如 果 不 为 空 , 则 应 用 iconvO 


函数 对 字符 串 的 编码 格式 进行 转换 。 然 后 ， 应 用 file_exists0 函 数 判 断 指 定 的 目录 或 者 文件 是 否 存 在 ， 如 果 存 在 
则 获取 目录 或 者 文件 的 类 型 、 大 小 以 及 修改 时 间 ， 其 关键 代码 如 下 : 
< 


php 
让 ($_ POST [file name’] (="") { // 判 断 表单 提交 的 值 是否 为 空 
S$file name = iconv ( "utf-8", "gb2312". $_POST ['file name'] ): // 完 成 编码 格式 的 转换 
if (file_exists ( $file name )) { 1/ 判断 目录 或 者 文件 是 否 存在 
Sfile_type = filetype ( $file_ name ): /获取 文件 类 型 
echo "<br> 文 件 类 型 : " . $file_type . "<br>": 
if(S$file type (= "dir") { // 判 断 如 果 不 是 目录 
Sfile_size = filesize ( $file_name ): /获取 文件 的 大 小 


echo "文件 大 小 :" . $file_size . " 字 节 " . "<br>"; 
} 
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能 。 本 实例 将 演示 如 何 通过 phpMyAdmin 修改 MySQL 用 户 密码 。 
图 关键 技术 


通过 phpMyAdmin 修改 MySQL 用 户 密码 的 方法 有 两 种 : 
(1) 直接 通过 phpMyAdmin 的 界面 进行 更 改 。 
(2) 通过 修改 phpMyAdmin 文件 夹 下 的 配置 文件 config php 实现 更 改 。 


图 设计 过 程 
1. 通过 phpMyAdmin 的 界面 进行 密码 修改 


(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 单 击 “ 修 改 密码 ”按钮 ， 如 图 8.119 所 示 。 
(2) 根据 页 面 提示 输入 新 密码 和 确认 密码 ， 如 图 8.120 所 示 。 
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图 8.119 ” phpMyAdmin 图 形 化 界面 图 8.120 ”修改 MySQL 数据 库 密码 
(3) 单 击 “ 执 行 ” 按 钮 ， 修 改 MySQL 数据 库 密 码 ， 如 图 8.121 所 示 。 
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图 8.121 完成 密码 修改 


2. 通过 修改 配置 文件 进行 密码 修改 
(1) 将 下 载 的 phppMyAdmin-x.zip 文件 解压 到 Apache 默认 的 根 目 录 下 ， 解 压 后 的 名 称 是 phpMyAdmin- 
2.x.x.x， 其 中 的 2.x.xx 是 版 本 号 ， 为 方便 使 用 ， 可 以 将 其 重新 命名 为 phpMyAdmin。 
(2) 打开 phpMyAdmin 文件 夹 ， 找 到 配置 文件 config.php， 然 后 使 用 记事 本 或 其 他 编辑 工具 打开 该 文件 ， 
找到 该 文件 中 的 以 下 内 容 进行 配置 : 
S$cfg[PmaAbsoluteUri] = http://127.0.0.1/phpMyAdmin ': 
以 上 用 于 设置 phpMyAdmin 的 URL， 例 如 http://127.0.0.1/phpMyAdmin。 
Scfe['blowfish_secret] = root: 
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心 法 领悟 446: 设置 统一 的 编码 格式 。 
在 创建 数据 表 字 段 时 ， 一 般 将 字符 类 型 的 数据 字段 设置 为 统一 的 编码 格式 ， 对 于 数值 型 数据 字段 ， 可 以 不 
进行 编码 格式 的 设置 。 


高 级 
实例 447 趣味 指数 : 8 克 友 区 
图 实例 说 明 


phpMyAdmin 可 以 实现 在 cmd 命令 行 下 对 数据 库 的 操作 , 而 且 操作 更 简单 、 直观。 本 实例 通过 phpMyAdmin 
实现 对 数据 库 的 创建 和 删除 操作 。 


图 关键 技术 

切记 ， 在 创建 数据 库 时 ， 一 定 要 设置 数据 库 的 编码 格式 。 注 意 ， 一 旦 执行 删除 操作 ， 数 据 库 将 不 能 再 恢复 。 
图 设计 过 程 

(1) 登录 到 phpMyAdmin 主页 ， 根 据 提示 编写 新 建 数据 库 的 名 称 并 设置 数据 库 的 编码 格式 ， 如 图 8.124 
所 示 。 

(2) 单 击 “ 创 建 ” 按 钮 ， 创 建 数据 库 并 自动 选择 创建 的 数据 库 为 当前 数据 库 。 


(3) 如 果 数 据 库 已 经 没有 任何 作用 ， 可 以 通过 phpMyAdmin 删除 数据 库 。 选 择 想 要 删除 的 数据 库 ， 单 击 导 
航 栏 中 的 “删除 ”按钮 ， 根 据 提示 决定 是 否 删除 数据 库 ， 如 图 8.125 所 示 。 
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国 秘笈 心 法 


心 法 领悟 447: phpMyAdmin 图 形 化 工具 与 cmd 命令 下 操作 数据 库 。 
通过 phpMyAdmin 图 形 化 工具 与 在 cmd 命令 下 操作 数据 库 没 有 任何 区 别 ， 只 是 phpMyAdmin 的 设计 者 对 
MySQL 数据 库 的 相关 指令 进行 了 封装 ， 使 一 些 对 MySQL 数据 库 不 了 解 的 用 户 也 可 以 操作 数据 库 。 
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力 实例 说 明 


对 数据 表 的 操作 一 般 包括 创建 和 删除 ， 本 实例 介绍 应 用 phpMyAdmin 图 形 化 工具 实现 对 数据 表 的 创建 和 删 
除 操作 。 


图 关键 技术 


想 要 创建 数据 表 ， 首 先 要 创建 数据 库 ， 当 数据 库 创建 完成 时 自动 选择 已 经 创建 好 的 数据 库 ， 根 据 提示 编写 
数据 表 名 称 并 创建 数据 表 。 而 删除 数据 表 时 ， 需 要 选择 想 要 删除 的 表 ， 然 后 单 击 “ 删 除 ” 按 钮 即 可 完成 。 


图 设计 过 程 
(1) 登录 到 phpMyAdmin 界面 ， 创 建 数据 库 ， 选 择 数据 库 编码 格式 ， 单 击 “ 创 建 ”按钮 ， 根 据 提示 编写 数 
据 表 名 称 ， 并 填写 想 要 创建 数据 表 的 字段 数目 ， 如 图 8.126 所 示 。 


(2) 进入 编写 数据 库 字 段 页， 建立 数据 表 结构 ， 填 写字 段 信息 ， 其 中 包括 字段 名 称 、 字 段 类 型 、 字 段 长 度 、 
是 否 允 许 为 空 等 ， 如 图 8.127 所 示 
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(3) 单 击 “ 保 存 ” 按 钮 ， 完 成 数据 表 的 创建 。 
(4) 删除 数据 表 时 ， 首 先 选择 要 删除 的 数据 表 名 称 并 进入 数据 表 操 作 界 面 ， 单 击 导航 栏 中 的 “删除 ”按钮 ， 
根据 提示 删除 数据 表 ， 如 图 8.128 所 示 。 


力 秘笈 心 ; 
心 法 领悟 448: 使 用 phpMyAdmin 图 形 化 工具 创建 数据 表 的 注意 事项 。 


在 创建 数据 表 结 构 时 也 要 对 数据 表 字 段 进 行 编码 格式 设置 ， 而 且 必须 为 数据 表 指 定 主键 、 设 置 索引 ， 和 否则 
会 出 现 如 图 8.129 所 示 的 提示 内 容 。 
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(2) 插入 数据 信息 。 单 击 导航 栏 中 的 “插入 ”按钮 ， 进 入 插入 信息 界面 ， 完 成 数据 的 添加 后 单 击 “ 执 行 ” 
按钮 ， 实 现 插入 数据 ， 如 图 8.131 所 示 。 

(3) 删除 数据 信息 。 首 先 返回 到 数据 浏览 页 ， 如 果 要 删除 单条 数据 信息 ， 直 接 单 击 该 条 数据 的 删除 按钮 ; 
如 果 要 删除 多 条 数据 信息 ， 可 以 选中 数据 信息 前 端的 复 选 框 ， 然后 单 击 数据 表 信息 下 端的 “选中 项 删除 ”按钮 ; 
如 果 要 删除 数据 表 中 的 所 有 信息 ， 可 以 单 击 导航 栏 中 的 “清空 ”按钮 ， 实 现 删除 所 有 数据 信息 ， 如 图 8.132 
所 示 。 
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图 8.131 插入 数据 信息 图 8.132 ”删除 数据 操作 


(4) 修改 数据 信息 。 修 改 数据 信息 与 删除 数据 信息 类 似 , 可 以 分 为 修改 单条 数据 信息 和 修改 多 条 数据 信息 。 
修改 单条 数据 信息 时 直接 单 击 该 条 数据 的 修改 按钮 进入 修改 页 面 ， 即 可 实现 修改 ， 修 改 多 条 数据 信息 时 ， 首 先 
要 选中 复 选 框 ， 然 后 单 击 “ 选 中 项 修改 ”按钮 ， al 汪 la 和 图 8.134 所 示 。 
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图 8.133 ”修改 数据 信息 图 8.134 更改 数据 信息 页 
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心 法 领悟 449: 在 phpMyAdmin 图 形 化 界面 工具 中 修改 操作 与 删除 操作 的 区 别 。 

如 果 在 修改 多 条 数据 时 ， 误 选中 不 需 更 改 的 数据 信息 前 的 复 选 框 ， 进 入 修改 页 面 后 可 以 不 对 此 条 数据 做 任 
何 修改 ， 此 条 数据 信息 不 会 有 任何 变化 。 如 果 在 删除 多 条 数据 时 ， 误 选中 了 不 需 删除 的 数据 信息 前 的 复 选 框 ， 
则 单 击 “ 执 行 ”按钮 后 信息 会 被 删除 。 
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9.1 PHP 的 MySQLi 扩展 库 


在 PHP 5.0 以 后 的 版 本 中 ,为 适应 MySQL 数据 库 的 新 特性 重新 编写 了 MySQLi 扩展 库 。MySQLi 扩展 库 同 
时 提供 了 面向 过 程 和 面向 对 象 的 两 种 调用 接口 ， 本 节 将 通过 具体 实例 讲解 如 何 使 用 MySQLi 扩展 库 对 MySQL 
数据 库 进行 操作 。 


A 连接 MySQL 数据 库 中 级 | 


力 实例 说 明 


本 实例 主要 实现 使 用 MySQLi 扩展 库 的 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 。 运 行 本 实例 ， 如 
9.1 所 示 ， 在 页 面 中 打印 出 数据 库 连 接 成 功 的 提示 信息 ， 从 而 说 明 已 经 成 功 连接 上 MySQL 数据 库 。 


9 www.mrboed.com 上 EE 4 
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9.1 数据 库 连接 成 功 


图 关键 技术 


使 用 MySQLi 扩展 库 面向 对 象 的 方法 建立 与 MySQL 数据 库 的 连接 ， 主 要 是 使 用 mysqli 类 实现 的 ， 该 类 的 
构造 方法 的 语法 格式 如 下 : 


class mysqli{ 
_construct ( [string host [, string usemame [, string passwd [, string dbname [, int port]]]]] ) 


} 
mysqli 类 的 构造 方法 的 参数 说 明 如 表 9.1 所 示 。 


表 9.1 mysqli 类 的 构造 方法 的 参数 说 明 


passwd MySQL 数据 库 服 务 器 密码 

dbname | 要 连接 的 MySQL 数据 库 的 名 称 

Port MySQL 数据 库 服 务 器 端口 号 ， 默 认为 3306 
图 设计 过 程 


(1) 创建 数据 库 db_database09。 在 MySQL 中 创建 数据 库 可 以 通过 SQL 语句 或 phpMyAdmin 图 形 化 管理 
工具 实现 ， 本 实例 将 采用 命令 方式 创建 MySQL 数据 库 ， 其 创建 代码 如 下 : 


CREATE DATABASE db _database09 ; 


(2) 使 用 函数 parse_ini file0 解 析 配 置 文件 config.ini 以 获得 数据 库 连 接 参 数 ,然后 使 用 new 关 键 字 对 mysqli 
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类 进行 实例 化 , 最 后 使 用 函数 mysqli connect_ermo0 判 断 是 否 成 功 连接 上 了 MySQL 数据 库 , 实现 该 过 程 的 代码 


如 下 : 
ty{ 
Sconfig = parse_ini file(realpath(dimame( FILE ).'/config/config ini]): /| 解析 config ini 文件 
Smysqli = new mysqli($config['host], $config[usemame], Sconfig[password]. Sconfig[dbname]): /对 mysqli 类 进行 实例 化 
imysqli_conneet_ ermoO){ // 济 断 是 否 成 功 连接 上 MySQL 数据 库 
了 hrow new Exception(<br/> 数 据 库 连接 错误 ! ，); /如果 连接 错误 ， 则 抛 出 异常 
lse{ 
echo 数据 库 连 接 成 功 !'; // 打 印 连 接 成 功 的 提示 
. 
jcatch (Exception $e){ /捕获 异常 
echo $e->getMessage(): /打印 异常 信息 


< 注意 : 使 用 MySQLi 扩展 库 完成 对 MySQL 数据 库 的 操作 后 , 还 应 该 通过 调用 MySQLi 类 实例 对 象 的 close0 
方法 释放 资源 。 


心 法 领悟 450: 使 用 MySQLi 扩展 库 的 面向 过 程 的 方式 连接 MySQL 数据 库 。 
使 用 MySQLi 扩展 库 不 仅 可 以 采用 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 ， 为 了 适应 不 同 开发 习惯 
用 户 的 需求 ， 同 时 提供 了 面向 过 程 的 方式 对 MySQL 数据 库 进行 管理 。 使 用 MySQLi 面向 过 程 的 方式 建立 与 


MySQL 数据 库 的 连接 是 通过 mysqli_connect0 函 数 实现 的 ， 该 函数 的 语法 格式 如 下 : 
mysqli_connect( [string host [, string username [, string passwd [, string dbname [, int port]]]]] ) 
该 函数 参数 的 使 用 方式 与 mysqli 类 的 构造 方法 相同 ， 这 里 不 再 袭 述 。 


力 实例 说 明 


在 Web 项 目 开发 过 程 中 ,经 常 需要 对 大 量 数据 信息 进行 查询 操作 ， 本 实例 主要 介绍 如 何 使 用 MySQLi 扩展 
技术 实现 商品 信息 的 检索 。 运 行 本 实例 ， 如 图 9.2 所 示 ， 在 图 中 文本 框 中 输入 要 查找 的 商品 名 称 ， 单 击 “ 查 找 ” 
按钮 ， 如 果 该 商品 存在 则 显示 该 商品 的 所 有 信息 ， 否 则 提示 没有 查找 到 该 商品 。 
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图 9.2 商品 信息 查询 


国 关键 技术 


在 MySQLi 扩展 库 面向 对 象 的 编程 方式 中 ， 可 以 使 用 mysqli 类 中 的 query0 方 法 执行 查询 操作 ,该 方法 的 语 
法 格式 如 下 : 

ixed query ( string query [, int resultmode] ) 

参数 说 明 : 

query: 要 执行 的 查询 语句 。 
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实例 
力 实例 说 明 
在 开源 项 目 开 发 中 ，MySQL 数据 库 被 广泛 应 用 。 这 不 但 因为 MySQL 数据 库 是 完全 免费 的 ， 而 且 MySQL 
数据 库 和 PHP 一样 都 是 完全 跨 平台 的 。 但 在 实际 项 目 开 发 过 程 中 ，PHP 与 MySQL 数据 库 产生 连接 错误 是 不 可 
避免 的 ， 本 实例 将 讲解 如 何 实现 尽 可 能 早 地 发 现 这 种 连接 错误 。 运行 本 实例 ， 分 别 如 图 9.3 和 图 9.4 所 示 。 图 中 


所 示 错 误 都 是 当 连 接 数 据 库 服务 器 时 用 户 密码 输入 错误 所 致 ， 其 中 图 9.3 在 页 面 中 打印 出 上 述 错误 的 信息 ， 
9.4 外 
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图 9.3 显示 错误 信息 图 9.4 显示 错误 号 


图 关键 技术 


在 MySQLi 扩展 技术 中 ， 可 以 使 用 两 种 方式 获得 数据 库 连接 错误 报告 ， 一 种 是 直接 获取 错误 的 名 称 ， 另 一 
种 是 获取 连接 错误 所 代表 的 错误 号 。 

直接 获取 错误 的 名 称 可 以 使 用 函数 mysqli_connect_error0 实 现 ， 该 函数 的 语法 格式 如 下 : 

string mysqli_connect_error(mysqli link) 

该 函数 将 返回 一 个 错误 消息 ， 该 消息 对 应 于 使 用 MySQLi 扩展 技术 连接 MySQL 数据 库 时 所 产生 的 错误 。 

获取 连接 MySQL 数据 库 时 产生 的 错误 号 可 以 使 用 函数 mysqli_connect_errno() 实 现 ， 该 函数 的 说 明 如 下 : 

int mysqli_connect_errno() 

如 果 在 连接 MySQL 数据 库 服 务 器 时 出 现 了 错误 ， 就 会 产生 一 个 该 错误 对 应 的 消息 数字 ， 利 用 该 函数 就 可 
以 获取 该 数字 。 下 面 为 连接 MySQL 数据 库 时 可 能 发 生 错 误 的 错误 号 及 错误 内 容 : 

1045: Access denied for user ' 用 户 名 '@' 用 户 密码 '(user password:YES) 

上 述 错误 代表 用 户 密码 输入 错误 。 

2005: Unknown MySQL server host "MySQL 数据 库 服务 器 名 (11004) 

上 述 错误 代表 MySQL 数据 库 服务 器 名 称 输入 错误 。 


2013: Loset connection to MySQL server during query 


上 述 错 误 代表 在 执行 查询 时 失去 了 与 MySQL 数据 库 的 连接 。 
痊 提示 : 在 项 目 开发 中 ， 可 以 通过 try/catch 语句 捕获 通过 MySQLi 扩展 库 连 接 MySQL 数据 库 所 产生 的 异常 。 


力 设计 过 程 
(1) 建立 index.php 文件 ， 用 于 建立 PHP 与 MySQL 数据 库 的 连接 ， 并 输入 错误 的 用 户 密码 ， 代 码 如 下 : 
S$conn=mysqli_connect("localhost"."root". "root1"): // 建 立 与 MySQL 数据 库 的 连接 
echo mysqli_connect_errnoO); /打印 错误 号 
(2) 建立 index_1.php 文件 ,用 于 建立 PHP 与 MySQL 数据 库 的 连接 ， 并 输入 错误 的 用 户 密码 ， 代 码 如 下 : 
$conn=mysqli_connect("localhost"."root". "root1"): // 建 立 与 MySQL 数据 库 的 连接 
echo mysqli_connect_error(); /打印 错误 提示 
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$sql=$conn->query("select * from tb_studenttb_score where tb_student id=tb_score.sid"): /| 执行 关联 查询 
Sinfo=$sql->fetch_array(MYSQLI ASSOC): // 获 得 查询 结果 集 
if($info—NULD){ // 未 查 到 结果 ， 将 给 出 提示 
echo " 暂 无 学 生 信 息 ": 
jelsef 
dof 
ry 
<t> 


<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sno]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[yw]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $infofwy]:?></div></td> 
<td bgeolor="#FFFFFF"><div align="center"><?php echo $info[sx];?></div></td> 
<i> 
<php 
jwhile( Sinfo=$sql->fetch_array(MYSQLIL ASSOC)); // 通 过 循环 打印 成 绩 信息 


> 


心 法 领悟 453: 使 用 隐 式 连接 查询 实现 多 表 之 间 的 关联 查询 。 
实现 本 实例 所 采用 的 多 表 之 间 的 关联 查询 称 为 显示 关联 查询 ， 查 询 语句 如 下 : 


select * from tb_student,tb_score where tb_student.id=tb_score.sid 
除了 使 用 上 述 显示 关联 查询 外 ， 还 可 以 使 用 内 连接 查询 方式 实现 多 表 之 间 的 隐 式 关联 查询 ， 如 本 实例 的 多 
表 连 接 查询 可 以 更 改 成 如 下 形式 : 


select * from tb_student inner join tb_score on tb_student.id=tb_score.sid 
上 述 内 连接 查询 中 ， 使 用 inner join 子 句 指定 要 连接 的 表 名 ， 使 用 on 子 句 指定 两 个 表 的 连接 条 件 ， 如 果 还 
有 其 他 查询 条 件 ， 可 以 指定 where 子 句 。 


[ED 说 明 : 为 了 规范 数据 库 查询 技术 ， 隐 式 查询 方式 将 成 为 多 表 连 接 查询 的 主流 方式 。 


技术 实现 内 存 的 回收 初级 | 


力 实例 说 明 


为 了 有 效 利用 服务 器 的 内 存 空 间 ， 在 获取 较 大 结果 集 时 ， 一 旦 结束 操作 则 有 必要 回收 集合 所 需要 的 内 存 ， 
由 于 MySQLi 技术 可 以 采用 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 所 以 与 之 对 应 的 内 存 回收 方式 也 有 两 种 ， 笔 者 
将 通过 本 实例 讲解 内 存 回收 机 制 在 项 目 开发 过 程 中 的 意义 和 使 用 方法 。 运 行 本 实例 ， 如 图 9.6 所 示 ， 图 中 为 某 
班级 学 生 主要 科目 成 绩 的 列表 ， 并 在 显示 完 该 班 成 绩 后 对 内 存 进行 了 回收 。 


0312315 EI 加 54 
1915 3 加 5 | 四 
ED 商人 全 加 加 
EE EE 加 回 加 


图 9.6 学 生成 绩 列表 


图 关键 技术 


PHP 为 了 迎合 不 同 开发 习惯 的 程序 员 , 在 MySQLi 扩 展 技术 中 提供 了 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 
所 以 实现 内 存 回收 也 存在 与 之 对 应 的 两 种 方式 。 如 果 采 用 面向 过 程 的 编程 方式 ， 可 以 通过 如 下 函数 实现 内 存 
回收 : 


第 9 章 MySQL 高 级 应 用 技术 
bool mysqli_close ( object link) 
参数 link 指 mysqli_connect0 函 数 返 回 的 数据 库 连接 句柄 。 


如 果 采 用 面向 对 象 的 编程 方式 ， 可 以 通过 如 下 语句 实现 : 
Tink->close0) 


link 指 PHP 预定 义 的 mysqli 类 实例 化 后 的 对 象 。 
图 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 MySQL 数据 库 之 间 的 连接 。 在 conn.php 文件 中 ， 首 先 使 用 new 关键 字 
对 mysqli 类 进行 实例 化 ， 然 后 通过 实例 后 的 对 象 调用 query0 方 法 执行 查询 来 设置 数据 库 的 字符 编码 为 UTF-8 


编码 ， 其 实现 代码 如 下 : 
S$conn=new mysqli("localhost", "root","111","db_database09"); /建立 与 MySQL 数据 库 的 连接 
S$conn->query("set names utf8"); /设置 数据 库 字符 编码 


(2) 通过 do...while 循环 显示 该 班级 所 有 学 生 的 成 绩 。 实 现 该 功能 时 ， 首 先 使 用 include_once 语句 包含 
conn.php 文件 ,然后 通过 调用 query0 方 法 执行 查询 ,并 使 用 fetch_array0 方 法 获得 查询 结果 集 , 最 后 通过 do...while 
循环 在 页 面 中 打印 出 学 生 的 成 绩 信息 ， 实 现 该 过 程 的 代码 如 下 : 


<?php 
inelude_once("conn.php"); // 包 含 conn.php 文件 
$sql=$conn->query("select * from tb_student,tb_score where tb_studentid=tb_score.sid"); /执行 查询 
Sinfo=$sql->fetch_array(MYSQLI ASSOC): // 获 得 查询 结果 集 
if($info—NULL){ 

echo " 暂 无 学 生 信息 ": 
yelse{ 

dof // 通 过 循环 打印 查询 结果 


?> 
<tr> 
<td height="20" bgeolor="#FFFFFF"><div align="center"><?php ccho $info[sno]:?></div></td> 
<td bgeolor="#FFFFFF "><div align=reenter'><?php echo $info[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[yw]:? 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[wy]: 
<td bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sx]:?></div></td> 
<ir> 


ee 
> 
(3) 实现 内 存 的 回收 ， 这 里 分 别 调用 执行 query0 方 法 返回 对 象 的 close0 方 法 和 mysqli 实例 后 对 象 的 
close0 方 法 释放 资源 ， 代 码 如 下 : 


$sql->close(); 
Sconn->close(); 


国 秘笈 心 法 


心 法 领悟 454: 如 何 防止 页 面 出 现 中 文 乱码 。 

编写 PHP 程序 时 ,为 了 防止 页 面 出 现 乱 码 ,要求 PHP 
文件 编码 、 网 页 页 面 编 码 和 数据 库 编码 要 一 致 ， 如 果 采 
用 UTF-8 编码 , 则 上 述 三 项 内 容 都 要 设置 为 UTF-8 编码 ， 
否则 会 出 现 乱码 现象 ， 那 么 如 何 对 上 述 编 码 进行 设置 
呢 ? 设置 PHP 文件 编码 可 以 采用 UltraEdit、Edit Plus 和 
Zend Studio 等 编辑 器 ， 如 使 用 UltraEdit 设置 PHP 页 面 
文件 编码 时 , 可 以 在 另存 页 面 文件 时 选择 格式 为 UTF-8， 
如 图 9.7 所 示 。 

设置 网 页 的 页 面 编码 可 以 使 用 PHP 中 的 header0 函 数 
或 在 HTML 的 meta 标记 中 进行 。 如 果 页 面 完全 由 PHP 


图 9.7 使 用 UltraEdit 另存 PHP 文件 为 UTF-8 编码 格式 
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(2) mysqli_fetch_ row 函数 根据 所 获取 的 记录 生成 数组 ， 如 果 没有 更 多 记录 则 返回 NULL， 其 语法 如 下 : 
mixed mysqli fetch row( mysqli_result result ) 


参数 result 为 mysqli_query0 函 数 执行 查询 后 的 返回 值 。 
图 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 MySQL 数据 库 的 连接 。 在 conn.php 文件 中 ， 首 先 使 用 mysqli connectO 
函数 连接 db_database09 数据 库 ， 用 户 名 是 root， 密 码 为 111。 然 后 通过 mysqli_connect_error0 函 数 定义 错误 信 
息 ， 最 后 通过 mysqli query0O 函 数 设置 数据 库 的 编码 格式 ， 其 代码 如 下 : 


$conn=mysqli_connect("localhost","root"."111","db_database09": /连接 数据 库 
if (mysqli_connect errnoO) { 
printf(" 连 接 失败 : %s\n", mysqli_connect_error0);: // 返 回 错误 信息 
exit|; 
} 
ri query($conn,"set names utf8"); // 设 置 数据 库 编码 格式 


Er 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登 录 的 用 户 名 和 密码 提交 到 index_ok.php 文件 处 理 。 
(3) 创建 index_ok.php 文件 ,获取 表单 提交 的 用 户 名 和 密码 ,根据 mysqli_fetch row() 函 数 的 返回 值 判断 登 
录 的 用 户 名 和 密码 是 否 正确 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 


include("conn/conn.php"); // 包 含 数据 库 连 接 文 件 
if($_POST['user]!="" || $_POST['pass]!=""){ // 判 断 用 户 名 和 密码 是 否 正 确 
$sql=mysqli_query($conn,"select + from tb_login where username=".$_POST['user].”" and password=".$_POST['pass]."™"); 
Sinfo=mysqli_fetch_row($sql): // 获 取 查 询 结 果 
if(Sinfo==NULL){ 
echo "<script>alert(' 登 录 失 败 ! "); window location href='index.php'</script>"; 
yelse{ 


echo "<script>alert(' 登 录 成 功 ! '); window.location href="index.php';</script>"; 


?> 
国 秘笈 心 法 
心 法 领悟 455: mysqli_fetch rowO 函 数 的 应 用 。 


根据 mysqli_fetch rowO 函 数 的 返回 值 不 但 可 以 判断 是 否 存在 查询 结果 ， 如 果 与 while 语句 结合 使 用 ， 还 可 
以 输出 查询 结果 中 的 数据 。 


力 实例 说 明 


在 本 实例 中 运用 mysqli 函数 库 中 的 mysqli_real_connect() 
函数 实现 与 MySQL 数据 库 的 连接 , 从 而 实现 用 户 注 册 的 功能 ， 
并 且 介 绍 一 种 检测 SQL 语句 中 错误 的 方法 。 运行 本 实例 , 输入 
用 户 的 注册 信息 ， 如 果 用 户 输入 的 用 户 名 已 经 存在 ， 则 输出 用 
户 名 已 经 存在 的 提示 信息 ， 否 则 提示 用 户 注册 成 功 ， 其 运行 结 
果 如 图 9.10 所 示 。 


初级 | 
起 呆 指数 : 机 机 页 | 


图 9.10 用 户 注册 
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1 
mysqli_query($conn."set names gb2312"); 1/ 设置 数据 库 编码 格式 
(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 注册 信息 提交 到 index_ok.php 文件 进行 处 理 。 


(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 用 户 注册 信息 ， 首 先 判断 提交 的 用 户 名 是 否 被 占用 ， 如 果 未 
被 占用 ， 则 将 用 户 注册 信息 添加 到 tb_reg 表 中 ， 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=gb2312" ); /设置 页 面 编码 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
if($_POST['user]!="" || $_POST[pwd1]!="" ){ // 判 断 输 入 的 用 户 名 和 密码 是 否 为 空 
Scheck="select name from tb_reg where name=".$_ POST[user]."": /定义 验证 用 户 名 是 否 被 占用 的 SQL 
Sresult=mysqli_query($conn,$Scheck): // 执 行 查询 语句 
Sinfo=mysqli_fetch_row($result); // 获 取 查 询 结 果 
if($info!=NULL) 


{ 
echo "<script>alert(' 您 输入 的 用 户 名 已 经 存在 ! ): window.location href~'index.php':</script>"; 
Jelse{ 
ee 
values(".$_POST['user']."" .md5($_POST['pwd1"]).",".$_POST['email].",".$_POST['address'].")"; 
Sresult=mysqli_query(Sconn,$sql);: 


echo mysqli_error(Sconn): /返回 SQL 语句 中 的 错误 信息 
if($result){ 

echo "<script>alert(' 注 册 成 功 !"); window.location.href='index.php';</script>"; 
jelsef 


echo "<script>alert( 注 册 失败 !0; window.location.href='index.php';</script>"; 
} 
} 
} 


2> 


图 秘笈 心 法 
心 法 领悟 456: 检测 SQL 语句 中 的 错误 。 


在 mysqli 函数 库 中 ， 可 以 通过 mysqli_error0 函 数 来 检测 程序 SQL 语句 中 的 错误 ， 以 帮助 我 们 及 时 地 发 现 
SQL 语句 中 的 问题 。 


力 实例 说 明 


在 前 面 的 实例 中 介绍 了 如 何 通过 mysqli 函数 库 中 的 函 
数 实现 用 户 注册 和 登录 的 功能 ， 在 本 实例 中 将 介绍 如 何 通 
过 mysqli 函数 库 中 的 函数 完成 数据 的 浏览 操作 。 运行 本 实 
例 ， 将 循环 输出 数据 库 中 指定 数据 表 的 数据 ， 其 运行 结果 
如 图 9.11 所 示 。 


图 关键 技术 


在 本 实例 中 ， 获 取 查询 结果 中 数据 应 用 的 是 mysqli_fetch_object0 函 数 ， 并 结合 while 语句 完成 其 返回 对 象 
中 数据 的 输出 。 
mysqli_fetch_object0 函 数 返 回 一 个 由 执行 查询 后 生成 的 表 字段 组 成 的 对 象 ， 其 语法 如 下 : 


mixed mysqli_fetch_object(object result) 
参数 result 为 mysqli_query0 函 数 执行 查询 的 返回 值 。 
获取 返回 对 象 中 数据 的 格式 如 下 : 


9.11 浏览 注册 用 户 
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<?php echo $obj->name; ?> 


其 中 $obj 为 返回 的 对 象 ，name 为 字段 名 称 。 
图 设计 过 程 


(1) 建立 conn.php 文件 实现 与 MySQL 数据 库 之 间 的 连接 。 

(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登 录 信息 提交 到 index_ok.php 文件 进行 处 理 。 

(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 用 户 登录 信息 ， 判 断 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 
确 ， 则 将 登录 用 户 名 存储 到 SESSION 变量 中 并 跳 转 到 main php 文件 ， 其 代码 如 下 : 


<?php 

session_start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 


if($_POST['user]!="" | $_POST['pass']!="){ 
$sql=mysqli query($conn,"select + from tb login where usemame=".$ POST['user']." and password=".$ POST['pass"].""): 
Sinfo=mysqli_fetch_row($sql): 
这 Sinfo 一 NULLJ{ 
echo "<script>alert(' 登 录 失 败 ! '); window.location href-index php'<lscript>": 
jelsef 
$_SESSION['user]=$_POST['user]; 
echo "<script>alert( 登 录 成 功 ! '); window.location href="main.php';</script>"; 
} 
} 


?> 
(4) 创建 main.php 文件 ， 连 接 数据 库 类 执行 查询 语句 ， 应 用 mysqli_fetch_object0 函 数 和 while 语句 完成 数 
据 库 中 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

session start(); 

include("conn/conn.php"):; 

if($_SESSION['user]==true){ 
> 


7 
/| 省 略 部 分 代码 
<2php 

$sql=mysqli_query($conn."select name,email.address from tb_reg "); 
Dm 


Ss 
<td height="22" align="center"><?php echo $obj->name:?></td> 
<td align="center"><?php echo substr($obj->email.0.20):?></td> 
<td align="center"><?php echo $obij->address:?></td> 
</t> 
<?php 
} 


> 
/省 略 部 分 代码 


echo "<script>alert( 您 不 具备 访问 权限 ! '):window ,location href-index.php':</script>": 


2> 


国 秘笈 心 法 


心 法 领悟 457: 返回 查询 结果 集中 的 数据 。 

返回 查询 结果 集中 的 数据 ， 不 但 可 以 使 用 mysqli_fetch_object0 函 数 ， 还 可 以 使 用 mysqli_fetch_array()、 
Imysqli_fetch_assocO0 和 mysqli_fetch row0 函 数 。 

通过 mysqli_fetch_array0 函 数 返 回 的 查询 结果 集 可 以 使 用 数字 索引 或 者 关联 索引 来 读 取 数据 ; 而 通过 
mysqli_fetch_assoc0 函 数 返 回 的 查询 结果 集 必须 使 用 关联 索引 来 获取 数据 ， 通 过 mysqli_fetch_row0 函 数 返回 的 
查询 结果 集 必须 使 用 数字 索引 来 获取 数据 。 
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实例 458 中 数据 的 动态 输出 


力 实例 说 明 


在 本 实例 中 应 用 mysqli 函数 库 中 的 函数 动态 地 对 数据 库 和 数据 表 进 行 操作 ,统计 数据 表 中 的 字段 和 记录 数 ， 
并 且 循 环 输 出 数据 表 中 的 数据 ， 其 运行 结果 如 图 9.12 所 示 。 
入 数据 施 识 六 


FS5:[ 3 
二 共 月 字 生 ;个 如家 并 记录 条 


这 same 


日 


9.12 浏览 注册 用 户 


力 关键 技术 
(1) 统计 查询 结果 中 的 字段 数 应 用 的 是 mysqli_num_fields0 函 数 ， 其 语法 如 下 : 


int mysqli_num ficlds(mysqli_result result) 
参数 result 为 mysqli query0、mysqli_ store _result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(2) 统计 查询 结果 中 的 记录 数 应 用 的 是 mysqli_num rows() 函 数 ， 其 语法 如 下 : 


| 
参数 result 为 mysqli query0、mysqli_store_result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(3) 获取 数据 表 中 字段 信息 应 用 的 是 mysqli_fetch_fields0 函 数 。 它 返回 一 个 对 象 数 组 ， 该 数组 包含 某 表 字 
段 的 信息 ， 如 果 该 表 的 字段 为 空 ， 则 返回 FALSE， 其 语法 如 下 : 


amray mysqli_fetch_ficlds(mysqli_result result) 


参数 result 为 mysqli_query0 函 数 的 返回 值 ， 返 回 的 对 象 数组 可 以 调用 的 属性 如 表 9.5 所 示 。 
表 9.5 mysqlLfetch_fields() 函 数 返 回 的 对 象 数组 可 以 调用 的 属性 说 明 


属 性 说 了 明 

name 返回 字段 的 名 称 

orgname 返回 字段 的 原始 名 称 
table 返回 字段 所 属 的 表 名 
orgtable 返回 字段 所 属 的 原始 表 名 
def 返回 该 字段 的 默认 值 
max_length 返回 字段 的 最 大 宽度 
length 字段 的 宽度 
charsetnr 返回 字段 所 属 的 字符 集 
flags 返回 一 个 描述 字段 的 位 标记 
type 返回 字段 的 数据 类 型 
decimals 返回 字段 小 数 部 分 的 位 数 
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心 法 领悟 458: 动态 读 取 数据 库 的 优势 。 
动态 读 取 数据 库 可 以 增加 页 面 的 灵活 性 ， 不 必 拘 泥 于 某 个 数据 库 、 数 据 表 的 格式 ， 此 方法 更 适合 于 在 后 台 
管理 系统 中 对 数据 进行 管理 。 


9.2 ”MySQL 视图 的 应 用 


视图 也 称 虚 表 ， 包 括 执行 某 个 查询 返回 的 一 组 记录 。 视 图 可 以 简化 获取 数据 的 方法 ， 并 通过 别名 来 实现 抽 
象 查询 。 


实例 459 趣味 指数 : 请 祖 请 


初级 


实例 说 明 


为 了 简化 查询 、 提 高 系统 安全 性 ， 在 项 目 开发 过 程 中 ， 通 常 采 用 为 数据 库 中 的 某 个 表 建 立 视图 的 方式 。 在 
建立 的 视图 中 只 有 开发 人 员 所 关心 的 字段 。 运 行 本 实例 ， 如 图 9.13 所 示 ， 分 别 在 图 中 输入 登录 用 户 的 用 户 名 和 
密码 ， 单 击 “ 进 入 ”按钮 后 ， 如 果 用 户 输入 的 用 户 名 或 密码 错误 则 给 出 错误 提示 ， 反 之 ， 如 果 输 入 的 用 户 名 和 
密码 正确 ， 则 提示 成 功 登录 。 由 于 本 实例 采用 视图 建立 了 虚 表 ， 所 以 应 首先 在 命令 提示 符 窗 口中 建立 视图 ， 如 
图 9.14 所 示 。 


企业 客服 管理 系统 


图 9.13 用 户 身份 验证 图 9.14 创建 视图 


图 关键 技术 
在 MySQL 中 创建 视图 可 以 通过 create view 语句 来 实现 ， 具 体 创建 格式 如 下 : 


create [ or deplace] [algorithm={merge | temptable | undefined}] view view_name [( column list)] as select_statement [with [cascaded |local] check 
option] 


参数 说 明 : 

view_name: 新 建 视图 的 名 称 。 

select_statement: SQL 查询 语句 ， 用 于 限定 虚 表 的 内 容 。 

algorithm={merge | temptable | undefined} 属 性 用 于 优化 MySQL 视图 的 执行 ， 该 属性 有 3 个 可 用 的 设置 。 下 
面 将 介绍 这 3 个 设置 的 使 用 方法 

merge: 该 参数 将 MySQL 执行 视图 时 传 入 的 任何 子 句 合并 到 视图 的 查询 定义 中 。 

temptable: 如 果 视 图 低层 表 中 的 数据 有 变化 ， 将 在 下 次 通过 表 时 立即 反映 出 来 。 

undefined: 当 查 询 结果 和 视图 结果 为 一 一 对 应 关系 时 ，MYySQL 将 algorithm 设 定 为 temptable。 
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力 设计 过 程 


(1) 建立 数据 库 及 数据 库 表 。 本 实例 中 将 数据 表 命名 为 也 _admin， 其 创建 过 程 可 以 通过 phpMyAdmin 实现 。 
(2) 完成 数据 表 的 创建 后 ， 在 命令 提示 符 下 建立 视图 ， 创 建 视图 的 代码 如 下 : 


create view chkadmin as select name, pwd from tb_admin 
创建 的 视图 chkadmin 中 只 包含 name 和 pwd 两 个 字段 信息 ， 这 样 使 得 程序 的 其 他 字段 信息 不 可 见 ， 从 而 可 
以 有 效 提 高 程序 的 安全 性 。 
(3) 采用 PHP 中 的 MySQL 函数 库 建立 与 MySQL 数据 库 的 连接 。 首 先 使 用 mysql_connect0 函 数 连接 
MySQL 数据 库 ， 然 后 使 用 函数 mysql_select_db0 选 择 数 据 库 db_database09， 最 后 使 用 函数 mysql_query0 执 行 
set names utf8 语句 来 设置 数据 库 的 编码 为 UTF-8 编码 ， 实 现 该 过 程 的 代码 如 下 : 


Sconn=mysql_connect("localhost","root","111"); // 建 立 与 MySQL 数据 库 的 连接 
mysql_select_db("db_database09", Sconn): // 选 择 数据 库 
mysql_query("set names utf8"); // 设 置 数据 库 字符 编码 
(4) 判断 用 户 是 否 单 击 了 “进入 ”按钮 ， 如 果 是 ， 则 通过 视图 chkadmin 对 用 户 身份 进行 验证 ， 该 过 程 的 
代码 如 下 : 
if($_POST[submit]!=""){ 
include_once("conn.php"); // 包 含 conn.php 文件 
Sname=$_POST[name]; // 接 收 提交 的 用 户 名 
Spwd=$_POST[pwd]; // 接 收 提交 的 用 户 密码 
$sql=mysql query("select * from chkadmin where name=".$name." and 
pwd=".$pwd."™",Sconn); // 执 行 查询 
Sinfo=mysql_fetch_array($sql): // 返 回 结果 集 
if($info=false){ /判断 用 户 名 和 密码 是 否 正确 
echo "<script>alert( 用 户 名 或 密码 输入 错误 1"):history.back0;</script>"; 
exit; 
jelse{ 


echo "<br><div align=center> 登 录 成 功 !</div>"; /如 果 正 确 则 提示 登录 成 功 
} 


国 秘笈 心 法 

心 法 领悟 439， 使 用 视图 的 实际 意义 。 

视图 在 项 目 开发 过 程 中 具有 非常 重要 的 实际 意义 ， 主 要 表现 在 如 下 两 点 : 

(1) 使 用 视图 可 以 使 查询 更 加 简化 。 在 程序 编写 中 , 如 果 所 要 执行 的 查询 较为 复杂 , 可 以 将 其 转化 为 视图 ， 
从 而 简化 查询 。 

(2) 使 用 视图 还 可 以 提高 程序 的 安全 性 。 如 果 只 想 让 用 户 访问 某 表 中 的 某 几 个 指定 的 字段 ， 可 以 创建 一 个 
只 包含 这 些 字 段 的 视图 ， 而 不 用 将 整个 表 的 所 有 字段 的 访问 权限 都 分 配给 该 用 户 。 


Cg 技巧 : 虽然 不 使 用 视图 也 可 以 完成 对 数据 库 的 操作 ， 但 在 字段 数量 较 多 或 安全 性 要 求 较 高 的 模块 中 建议 通 
过 视图 完成 查询 ， 从 而 有 效 地 提高 程序 的 可 维护 性 和 安全 性 。 


力 实例 说 明 


通过 本 实例 主要 讲解 如 何 对 已 经 创建 完成 的 MySQL 视图 进行 修改 ， 在 制作 本 实例 时 ， 首 先 需 要 在 数据 库 
中 创建 数据 表 tb_changeview， 其 结构 如 图 9.15 所 示 , 然后 创建 视图 userinfo, 该 视图 中 包含 tb_changeview 表 中 
的 所 有 字段 ， 完 成 上 述 操作 后 ， 使 用 alter view 语句 对 视图 进行 修改 。 


趣味 指数 : 依 癸 请 
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字 及 类 型 属性 Null 默认 籁 外 摊 作 
| mg) au menat 畔 户 X 图 民国 于 
memmame varrhar50y on2312 到 | 区 习 | 沪 |X| 加 | 加 | 加 | 加 
三 ”wserpwdl warcnar50 ob2312_thness_cl 至 必 上 XX 图 轩 回国 


图 9.15 创建 表 changeview 


图 关键 技术 


在 MySQL 中 修改 视图 可 以 通过 alter view 语句 实现 ，alter view 语句 的 具体 使 用 说 明 如 下 : 


alter view [algorithm={merge | temptable | undefined} Jview view_name [(column list)] as select_statement[with [cascaded | local] check option] 
参数 说 明 : 

algorithm: 该 参数 已 经 在 创建 视图 中 作 了 介绍 ， 这 里 不 再 次 述 。 

view_name: 视图 的 名 称 。 

select_statement: SQL 语句 ， 用 于 限定 视图 。 


图 设计 过 程 
(1) 使 用 phpMyAdmin 创建 数据 库 及 数据 库 表 ， 本 实例 中 将 数据 表 命 名 为 tb_changeview。 
(2) 使 用 create view 语句 创建 视图 userinfo， 其 创建 代码 如 下 : 


create view userinfo as select * from tb_changeview 


(3) 使 用 select 语句 查询 视图 userinfo， 查 询 代码 如 下 : 


select * from userinfo 
查看 执行 结果 ， 可 以 发 现 tb_changeview 表 中 的 所 有 字段 都 一 一 列 出 ， 如 图 9.16 所 示 。 
(4) 下 面 开 始 修改 视图 ， 要 求 修改 后 只 列 出 usermame 字段 ， 代 码 如 下 : 


I 
(5) 重新 查询 视图 userinfo， 从 结果 中 可 以 发 现 ,此 时 只 列 出 username 一 个 字段 ， 从 而 说 明 视 图 修改 成 功 ， 
如 图 9.17 所 示 。 


图 9.16 创建 新 视图 图 9.17 修改 视图 


人 注意 : 如 果 数 据 库 采用 UTF-8 编码 ， 在 命令 提示 符 下 通过 select 语句 显示 查询 结果 时 会 出 现 中 文 乱码 现象 。 
力 秘笈 心 法 


心 法 领悟 460: 在 phpMyAdmin 的 查询 窗口 中 创建 和 修改 视图 。 
在 实现 本 实例 时 ， 创 建 视图 的 过 程 是 在 Windows 系统 的 命令 提示 符 窗口 中 实现 的 ， 为 了 提高 开发 效率 、 简 
化 程序 开发 人 员 的 操作 , MySQL 数据 库 的 创建 和 维护 过 程 一 般 在 MySQL 的 图 形 管理 工具 phpMyAdmin 中 进行 ， 
phpMyAdmin 为 MySQL 数据 库 提供 了 较为 完善 的 创建 、 维 护 及 备份 等 操作 。 同 样 ， 如 果 使 用 phpMyAdmin 的 
查询 窗口 也 可 以 执行 SQL 命令 ， 所 以 可 以 在 该 查询 窗口 中 创建 视图 ， 其 具体 创建 过 程 如 下 : 
(1) 打开 phpMyAdmin 管理 页 面 并 选择 要 管理 的 数据 库 ， 单 击 如 图 9.18 所 示 的 “查询 窗口 ”按钮 打开 
phpMyAdmin 的 查询 窗口 。 
(2) phpMyAdmin 的 查询 窗口 如 图 9.19 所 示 ， 可 以 在 该 窗口 中 输入 SQL 命令 实现 对 指定 数据 库 及 表 的 查 
询 操作 。 例 如 在 该 查询 窗口 中 输入 创建 视图 的 SQL 命令 ， 然 后 单 击 图 中 的 “执行 ”按钮 即 可 成 功 地 实现 视图 的 
创建 操作 。 
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心 法 领悟 461: 在 phpMyAdmin 的 命令 窗口 中 删除 视图 。 
要 删除 指定 的 视图 , 可 以 在 phpMyAdmin 的 命令 窗口 中 实现 。 首先 打开 phpMyAdmin 的 命令 窗口 , 如 图 9.22 
所 示 ， 然 后 在 该 窗口 中 输入 drop view 语句 ， 最 后 单 击 “ 执 行 ” 按 钮 即 可 成 功 删除 指定 的 视图 。 


Run SQL queryoueries on sever ocalhost Bo 
ldrop view testview 


1 
BE me 


图 9.22 在 phpMyAdmin 的 命令 窗口 中 删除 视图 


实例 462 


力 实例 说 明 


在 实际 项 目 开发 过 程 中 数据 表 中 可 能 有 很 多 字段 ， 但 某 个 模块 可 能 只 需要 其 中 的 几 个 。 为 了 提高 查询 速度 
和 简化 操作 ， 可 以 将 该 模块 需要 的 字段 单独 提取 出 来 放 在 某 个 视图 中 ， 例 如 本 实例 涉及 学 生 表 和 成 绩 表 ， 在 建 
立 的 视图 中 只 含有 与 学 生成 绩 有 关 的 字段 ， 如 图 9.23 所 示 。 

运行 本 实例 ， 如 图 9.24 所 示 ， 图 中 查询 结果 显示 的 内 容 即 为 视图 中 所 有 字段 中 的 内 容 。 


视图 的 应 用 
16 至 星 星 上 中 但 
05312317 苗 少 全 S56 加 
| 用 
图 9.23 创建 视图 图 9.24 学 生成 绩 列表 


图 关键 技术 


本 实例 创建 的 视图 涉及 多 表 查 询 ， 这 说 明 多 个 表 之 间 可 以 通过 视图 来 组 合 为 一 个 整体 ， 这 样 对 视图 的 操作 
就 相当 于 多 表 查 询 。 但 如 果 这 些 表 中 有 相同 的 字段 ， 必 须 按 如 下 方式 书写 重 名 的 字段 : 

表 名 1 字段 名 . 表 名 2. 字段 名 … 
图 设计 过 程 

(1) 创建 视图 scoreinfo， 通 过 该 视图 显示 学 生成 绩 信息 ， 该 视图 的 创建 代码 如 下 : 


create view scoreinfo as select sno.sname yw:wy:sx from tb_student.tb_score where tb_student.id=tb_score.sid 
(2) 建立 数据 库 连接 文件 conn.php， 实 现 与 MySQL 数据 库 的 连接 ， 并 设置 数据 库 字 符 集 为 UTF-8 编码 ， 
代码 如 下 : 
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图 9.25 用 户 登 录 窗 口 图 9.26 登录 成 功 的 提示 信息 


图 关键 技术 


在 创建 本 实例 的 存储 过 程 中 ， 为 了 防止 结束 符 冲 突 ， 首 先 使 用 delimiter 语句 将 MySQL 默认 的 结束 符 “;” 
更 改 为 “//”， 然 后 创建 存储 过 程 ， 其 创建 代码 如 图 9.27 所 示 。 


图 9.27 创建 用 户 登录 验证 的 存储 过 程 


创建 完成 上 述 存储 过 程 后 ， 在 程序 中 使 用 call 语句 调用 要 执行 的 存储 过 程 ， 本 实例 使 用 MySQLi 扩展 库 执 
行 存储 过 程 ， 其 实现 代码 如 下 : 

$sql = $mysqli->query("call pro_login(™.$usemame.™, ".$password.")"): 
看 设计 过 程 


(1) 通过 MySQLi 扩展 库 建立 与 MySQL 数据 库 的 连接 ， 并 设置 数据 库 字 符 集 为 UTF-8， 实 现代 码 如 下 : 
Smysqli=new mysqli("localhost", "root","111"."db_database09"): 建立 与 MySQL 数据 库 的 连接 
Smysqli->query("set names utf8"); 设置 数据 库 字 符 编码 为 UTF-8 


(2) 建立 用 户 登录 表单 ， 当 用 户 在 表单 中 录入 用 户 名 和 密码 ， 并 单 击 “提交 ”按钮 后 ， 通 过 如 下 代码 验证 
用 户 的 登录 信息 是 否 正 确 : 


ifisset($_POST[usemame]) && trim($_POST['usemame"])!=") 判断 用 户 是 否 提交 了 表单 
require_once ‘Db.php': 包含 Db.php 文件 
S$usemame = trim($_ POST[usemame]): 获得 提交 的 用 户 名 
S$password = trim($_POST['password']); /获得 提交 的 用 户 密码 
$sql = $mysqli->query("call pro_login(".Susemame.", ".$password.")"): 调用 存储 过 程 ， 执 行 查询 
S$info = $sql->fetch_array(MYSQLI ASSOC): 获得 查询 第 一 条 记录 
if($info (= nulD{ 判断 是 否 为 NULL 值 
$_SESSION['loginUsemame'] = Susemame: 将 用 户 名 保存 到 SESSION 中 
echo ‘<script>window.location.href="success.php":</script>"; 重 定向 到 successphp 页 面 
Jelse { 


echo '<div style="width:300px: height:30px: line-height:30px: border:1px solid #FE59B04: background-color:#FCF2E0:; color 红 F0000:"> 用 户 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


力 设计 过 程 


(1) 通过 PHP 预定 义 类 mysqli 实现 与 MySQL 数据 库 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli("localhost". "root","111"."db_database09"); 
Sconn->query("set names utf8"); 

(2) 调用 存储 过 程 pro_reg 实现 将 用 户 录入 的 注册 信息 保存 到 数据 库 ， 代 码 如 下 : 
if($sql=$conn->query("call pro_reg(".$ne.™,". Spwd.™,".$email.™,".$address.")")){ 

echo "<script>alert( 用 户 注册 成 功 !);</script>"; 
}else{ 
echo "<seript>alert( 用 户 注册 失败 ;</script>"; 

} 


秘笈 心 法 

心 法 领悟 465: 使 用 PDO 数据 库 抽象 类 执行 存储 过 程 。 

实现 本 实例 时 ,使 用 MySQLi 扩展 库 执行 存储 过 程 ， 除 使 用 该 方法 外 ， 还 可 以 使 用 PDO 数据 库 抽象 类 执行 
存储 过 程 , 在 实现 本 实例 时 , 可 以 将 保存 用 户 注册 信息 的 代码 进行 如 下 更 改 , 来 演示 使 用 PDO 技术 执行 MySQL 
存储 过 程 的 方法 。 

$db = new PDO('mysql:host=localhost:dbname=db_database09', root', root); /实例 PDO 类， 连接 MySQL 数据 库 

$stmt = $db->prepare("call pro_reg(?. ?, ?, ?)"); // 建 立 查询 的 预 处 理 句 柄 

$stmt->bindParam(1.$_ POST[me]); // 饰 定 参 数 

$stmt->bindParam(2, $_POST[pwd]): 


Sstmt->bindParam(3, $_POST['email]); 
Sstmt->bindParam(4, $_POST['address']); 


$stmt->execute(); /执行 查询 
| 说 明 : 使 用 PDO 连接 MySQL 数据 库 时 ， 连 接 字 符 串 mysql:host=localhost:dbname=db_database09 中 内 容 的 
顺序 可 以 颠倒 。 


9.4 MySQL 触发 器 


触发 器 在 数据 库 系 统 开发 过 程 中 具有 非常 重要 的 作用 ， 例 如 可 以 防止 有 害 数 据 录 入 数据 库 、 可 以 改变 或 取 
消 insert、update 和 delete 语句 的 执行 及 在 一 个 会 话 中 监听 数据 库 中 的 数据 的 改变 。 


实例 466 


国 实例 说 明 


如 果 用 户 打 算 在 数据 库 中 通过 触发 器 实现 某 一 动作 的 监听 ， 那 么 首先 应 该 创建 触发 器 。 触 发 器 是 在 命令 提 
示 符 下 创建 的 ， 如 图 9.31 所 示 。 


图 9.31 触发 器 创建 过 程 
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图 关键 技术 


MySQL 数据 库 中 创建 触发 器 的 格式 如 下 : 
create trigger < 触发 器 名 称 > 

{ before | after} 

{insert | update | delete} 

for each row 

< 触发 器 SQL 语句 > 


参数 说 明 : 
create trigger < 触发 器 名 称 >: 创建 一 个 新 触发 器 ， 并 指定 触发 器 的 名 称 。 
{ before | after}: 用 于 指定 在 insert、update 或 delete 语句 执行 前 触发 还 是 在 语句 执行 后 触发 。 
on < 表 名 >: 用 于 指定 响应 该 触发 器 的 表 名 。 
for each row: 触发 器 的 执行 间隔 。for each row 通知 触发 器 每 隔 一 行 执行 一 次 动作 , 而 不 是 对 整个 表 执行 一 次 。 
< 触发 器 SQL 语句 >: 触发 器 要 执行 的 SQL 语句 。 
用 设计 过 各 
(1) 在 命令 提示 符 下 创建 数据 表 tb_test， 代 码 如 下 : 
create table tb_test(t_id varchar(20).t_name varchar(20)) 
(2) 将 换行 标记 转换 为 “//”， 代 码 如 下 : 
delimiter // 


(3) 创建 触发 器 ， 实 现 无 论 用 户 向 表 tb_test 添加 什么 数据 都 使 字段 t name 的 内 容 为 mrsoft， 代 码 如 下 : 
create trigger test_tri 
before insert on tb_test 
for each row 
set new.t_name="mrsoft’ 
(4) 向 表 tb_test 中 添加 一 条 记录 ， 并 查看 结果 ， 代 码 如 下 : 
insert into tb_test(t_id,t_name) values(‘mr0001', '123")// 
Select * from tb_test 


图 秘笈 心 法 
心 法 领悟 466: 触发 器 中 执行 多 条 SQL 语句 。 
如 果 该 触发 器 要 执行 多 条 SQL 语句 ， 要 将 多 条 语句 放 在 begin...end 块 中 。 


初级 
趣味 指数 : 让 相信 


实例 467 


力 实例 说 明 


在 MySQL 数据 库 中 创建 触发 器 前 应 先 查 看 数据 库 中 的 触 
发 器 ， 这 样 既 可 以 使 开发 人 员 对 指定 的 数据 库 中 的 所 有 触发 器 
及 其 功能 有 一 个 直观 的 把 握 ， 而 且 可 以 避免 创建 同名 或 类 似 功 
能 的 触发 器 。 运 行 本 实例 ， 如 图 9.32 所 示 ， 首 先 在 图 中 的 文本 
框 中 输入 要 查看 触发 器 的 数据 库 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， 
即 可 将 该 数据 库 中 所 有 触发 器 的 详细 信息 显示 出 来 。 图 9.32 查看 触发 器 


力 关键 技术 
查看 MySQL 数据 库 中 触发 器 的 详细 信息 ， 可 以 通过 如 下 语句 实现 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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删除 相关 id 的 工作 后 ， 还 没 来 得 及 删除 学 生 信息 表 中 该 学 生 的 信息 时 就 发 生 停电 等 意外 ， 则 再 重新 查找 该 学 生 
的 成 绩 时 是 无 法 查找 到 的 。 

本 实例 将 采用 事务 处 理 方式 ， 对 学 生 信息 表 和 学 生成 绩 表 中 的 数据 进行 删除 。 运 行 本 实例 ， 学 生 信息 及 学 
生成 绩 信息 分 别 如 图 9.33 和 图 9.34 所 示 。 当 删除 图 9.33 中 的 学 生 信息 后 ， 查 看 学 生成 绩 信息 时 可 以 发 现 ， 与 
该 学 生 对 应 的 成 绩 也 被 全 部 删除 。 


IT 
图 9.33 查看 学 生 信息 图 9.34 查看 学 生成 绩 
图 关键 技术 


事务 的 处 理 可 以 通过 PHP 的 预定 义 类 mysqli 的 以 下 方法 实现 。 

(1) autocommit(boolean): 该 方法 用 于 限定 查询 结果 是 否 自动 提交 ， 如 果 参 数 为 true 则 自动 提交 ， 如 果 参 
数 为 false 则 关闭 自动 提交 。MySQL 数据 库 默 认为 自动 提交 。 

(2) rollback(): 利用 mysqli 类 中 的 该 方法 可 以 实现 事务 的 回 滚 。 

(3) commitO0: 利用 该 方法 可 以 实现 提交 所 有 查询 。 


力 设计 过 程 


(1) 建立 数据 库 及 数据 表 并 实现 与 数据 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli("localhost", "root","111","db_database09"); 
S$conn->query("set names utf8"); 
(2) 显示 所 有 学 生 的 基本 信息 ， 代 码 如 下 : 
<?php 
include_once("conn.php"); 
$sql=$conn->query("select * from tb_stu"); 
S$info=$sql->fetch_array(MYSQLI_ASSOC); 
if($info—NULL){ 
echo " 暂 无 学 生 信息 !"; 
jslse{ 
dof 
?> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sname]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sno]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sage]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[saddress]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[ssfzh]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><a hre 仁 "javascript:if(window.confirm( 确 定 删除 该 学 生 信息 
么 ?) 一 true){fwindow location href='delete.php?id=<?php echo $info[id]:?>:}"> 删 除 </a></div></td> 
</t> 
php 
}while($info=$sql->fetch array(MYSQLI ASSOC)): 


?> 

在 实现 该 模块 功能 时 ， 可 以 利用 JavaScript 实现 该 页 与 delete.php 页 面 的 信息 传递 ， 代 码 如 下 : 

<a hre 全 "javascriptiiftwindow.confirm(' 确 定 删除 该 学 生 信息 么 ?2) 一 tme){fwindow.location hre 人 delete .php?id=<?php echo $info[id]:?>':}"> 删 除 </a> 
window 对 象 的 confirm0 方 法 用 于 弹出 一 个 对 话 框 ， 提 示 用 户 是 否 真正 删除 某 学 生 的 所 有 信息 。 


(3) 利用 事务 处 理 机 制 对 学 生 的 基本 信息 进行 删除 ， 代 码 如 下 : 
Sid=$ GET[id]: 
include_once("conn.php"): 
S$conn->autocommit(false): 
if(!$conn->query("delete from tb_sco where id=".$id.™")){ 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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参数 说 明 : 
string query: SQL 语句 。 
link_identifier: 连接 标识 。 
(3) mssql fetch_row0 函 数 取得 一 行 数据 ， 保 存 于 数组 中 ， 其 语法 如 下 : 
array mssql fetch row ( resource result ) 
参数 说 明 : 
resource result: 结果 集 。 
本 实例 与 SQL Server 建立 连接 的 代码 如 下 : 


$conn = mssql connect("localhost","sa",”") or die ("Connect MySQL False"): 
mssql_select_db("db_database10",$conn): 


图 设计 过 程 
在 本 实例 中 ， 通 过 mssql_connect0 函 数 连接 SQL Server， 应 用 mssql_query0 函 数 执行 查询 语句 ， 应 用 
mssql_fetch rowO 函 数 和 while 语句 完成 用 户 信息 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 
$conn = mssql_connect ( "localhost", "sa", "" ) or die ( "Connect SQL Server False" ); /连接 SQL Server 服务 器 
mssql_select_db ( "db_database10", $conn ); /| 连接 db_database10 数据 库 
if($_GET [id] ='1) { 
> 
<?php 
if($rs = mssql_query("select * from tb_demo01"){ // 如 果 返 回 结果 集 
while($rst = mssql_fetch_row($rs){ /循环 输出 结果 集 
?> 
<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[0]:?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[1]:?></td> 
<lt> 
<?php 
jelsef 
echo "<script>alert( 数 据 表 存在 问题 );</script>"; 
} 
i 
?> 
国 秘笈 心 法 


心 法 领悟 471: 如 何 检测 PHP 是 否 支持 SQL Server 数据 库 。 
编写 脚本 文件 ， 输 入 如 下 代码 ; 
<?php 
echo phpinfo0; 
> 
经 下 浏览 器 运行 本 文件 ， 如 果 网 页 中 显示 mssql 内 容 ， 表 示 PHP 支持 SQL Server 数据 库 。 
如 果 用 户 使 用 的 SQL Server 数据 库 是 2000 版 本 ， 可 能 会 出 现 unable connect server:localhost 错误 ， 造 成 这 
种 错误 的 原因 一 般 分 为 两 种 情况 : 
(1) 代码 存在 错误 。 检 查 SQL Server 服务 管理 器 是 否 处 于 正在 运行 的 状态 。 
(2) 系统 可 能 缺少 ntwdblib.dll 文件 。 用 户 可 以 手动 下 载 ntwdblib.dll-2000.80.2039.0 文件 ， 将 此 文件 复制 
到 Apache\bin 文件 夹 和 php\bin 文件 夹 下 ,然后 重启 SQL Server 服务 器 和 Apache 服务 器 即 可 。 也 可 为 SQL Server 
打上 sp4 补丁 ， 然 后 重启 服务 器 。 


10.2 操作 数据 库 
SQL Server 数据 库 与 MySQL 数据 库 虽然 都 是 存储 信息 的 载体 ， 但 是 在 操作 方法 与 函数 上 略 有 不 同 。 本 节 
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将 具体 讲述 对 SQL Server 数据 库 的 相关 操作 。 


力 实例 说 明 


在 进行 网 站 开发 过 程 中 ， 经 常用 到 对 指定 时 间 段 的 信息 检索 ， 例 如， 检索 指定 时 间 段 内 有 哪些 PHP 类 图 书 
出 版 等 。 运 行 本 实例 ， 当 单 击 “ 信 息 检 索 ” 超 链接 时 ， 将 显示 2009 一 2010 年 明日 科技 编写 的 所 有 PHP 类 图 书 ， 
其 运行 效果 如 图 10.3 所 示 。 


《PRP 范 网 字 并》 人 民 地 电 出 版 社 


《PRP 实 成 字典》 清华 大 学 出 版 社 
《pqP 同 络 坞 程 》 杰 财 大 学 出 版 社 


图 10.3 通过 ADO 实现 指定 时 间 段 的 信息 检索 


力 关键 技术 


本 实例 通过 ADO 操作 SQL Server 数据 库 ， 执 行 指定 时 间 段 内 的 信息 查询 操作 ， 其 信息 检索 的 SQL 语句 代 
码 如 下 : 


$sql = "select id,bname.price.pub from tb_demo03 where date>="2009-01-01' and date<="2010-12-31"; 
图 设计 过 程 
创建 index.php 文件 , 首先 通过 ADO 连接 SQL Server 数据 库 , 然后 建立 记录 集 , 实现 用 户 信息 的 循环 输出 ， 


其 关键 代码 如 下 : 
<?php 
$conn = new com ( "adodb.connection" ); 
$connstr = "provider = sqloledb:data source=PC-201006101638:uid=sa:pwd=:database=db_database10"; //ADO 连接 数据 库 
$conn->open ( $connstr ); 
if($_GET [id] ="1") { 
$sql = "select id.bname.price.pub from tb_demo03 where date>=2009-01-01' and date<="2010-12-31"; 
S$rs = new com ( "adodb recordset" ); 
Srs->open ( $sql, Sconn ); 
if($rs->eof || $rs->bof) { 
echo "数据 库 暂 无 信息 ": 
Yelsef{ 
> 


<tr> 
<td align="center 吃 图 书 ID</td> 
<td align="eenter 必 图 书 名 称 </htd> 
<td align="center 必 图 书 价格 <ltd> 
<td align="center 吃 出 版 社 </td> 
<t> 


while (1 Srs->eof ) { 
?> 


<tr> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srs->ficlds (id )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srs->ficlds ( bname )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( "gbk', ‘utf-8'. $rs->ficlds ( price )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( "gbk', ‘utf-8'. $rs->fields (pub )->value ): ?></td> 
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心 法 领悟 472， 解决 页 面 乱码 问题 。 


由 于 在 SQL Server 中 使 用 的 编码 格式 是 GBK, 而 页 面 中 的 编码 格式 为 UFT-8, 所 以 需 使 用 转 码 函数 iconv0 
对 输出 结果 进行 转 码 ， 否 则 将 输出 乱码 。 


实例 473 


力 实例 说 明 


在 实际 开发 中 ， 很 多 程序 都 会 涉及 对 信息 的 检索 。 运 行 本 实例 ， 输 入 商品 ID， 单 击 “ 检 索 ” 按 钮 ， 将 查找 
出 匹配 的 商品 信息 并 且 对 商品 名 称 描 红 显 示 ， 运 行 结果 如 图 10.4 所 示 。 


通过 ADO 方 式 实现 指定 时 间 段 的 信息 检索 
0 


ee EB 


而 ID 商品 训 称 两 而 从 检 商品 类 型 
了 液晶 电视 S00 元 系 也 


10.4 商品 信息 的 检索 


图 关键 技术 


本 实例 通过 mssql_connectO 函 数 连接 SQL Server 服务 器 ， 通 过 mssql_ select_ db0 函 数 连接 db_database10 数 
据 库 ， 通 过 mssql_query0 函 数 执行 查询 语句 ， 通 过 mssql_fetch row0 函 数 获取 查询 结果 中 的 数据 ， 其 关键 代码 


如 下 : 
<?php 
$conn = mssql_connect ( "localhost", "sa", "" ) or die ( "Connect SQL Server False" ); /连接 数据 库 服务 器 
mssql_select_db ( "db_database10", $conn ) or die ( "Connect Database False" ); // 连 接 数据 库 
if($_POST [sub]) { // 判 断 提交 按钮 是 否 为 空 
让 ($_POST [text] 一 "||$_POST [texd] 一 "输入 商品 ID") { // 如 果 提交 ID 值 为 空 ， 则 给 出 提示 信息 
echo "<script>alert( 请 输入 查询 关键 字 ');</script>"; 
}else{ 
S$rs = mssql_query ( "select + from tb_demo04 where id=" . $_POST [text] ); // 执 行 查询 语句 
> 
看 设计 过 程 
(1) 在 index.php 文件 中 首先 创建 form 表单 ， 将 商品 的 ID 值 提交 到 本 页 ， 其 代码 如 下 : 
<form action="" method="post"> 


<input class="one” type="rext” name="text” value=" 遂 入 咬 咒 1D" size="15" onfocus="this.value="" /> 
<input class="fwo" type="submit” name="sub" value="@nbsp;" (> 
</form> 


(2) 在 index.php 文件 中 ， 通 过 mssql_connect0 函 数 连接 SQL Server， 根 据 form 表单 中 提交 的 ID 值 执行 


查询 语句 并 循环 输出 查询 结果 ， 代 码 如 下 : 


<Iphp 
Sconn = mssql_connect ( "localhost", "sa". "" ) or die ( "Connect SQL Server False" ): 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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内 部 的 行 指针 移动 到 指定 的 行 号 。 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE， 其 语法 如 下 : 


bool mssql data_seek( resource result identifier, int row_number ) 
参数 说 明 : 
result_identifier: 返回 类 型 为 resource 的 结果 集 ， 该 结果 集 从 mssql_ query0 函 数 的 调用 中 得 到 。 
row_number: 想 要 设 定 的 新 的 结果 集 指针 行 数 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 ， 首 先 创建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 对 表单 中 提交 的 定位 查 
询 数据 进行 判断 ， 如 果 提 交 的 值 正确 ， 则 应 用 mssql _data_seek(0 函 数 定位 指针 位 置 ， 通 过 mysql_fetch row0 函 数 
获取 查询 结果 中 的 记录 集 ; 否则 给 出 提示 信息 ， 并 且 通 过 while 语句 和 mssql_fetch_row0 函 数 循环 输出 数据 库 中 
的 所 有 记录 ， 其 关键 代码 如 下 : 


这 ($_POST [text] 一 "||$_POST [text] 一 "请 输入 数字 ") { 
echo "<script>alert( 请 在 文本 框 中 输入 信息 ”);</script>"; 
}else { 
if(! preg_match (Ad $_POST [text] )) { 


echo "<script>alert(' 请 输入 数字 ')</script>"; 
} else { 
if(@mssql data seek (Srs,$ POST [text]) { 
ss= mssql_feteh_row ( $rs ); 
<tr> 
<td style="background: HFFFFFF"><?php echo iconv (‘gbk’, utf-8', sts [0] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Sts [1] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $ts [2] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk', ‘utf-8', $ts [3] )?></td> 
<ltr> 
?php 
} else { 
echo "<script>alert( 输 入 无 效 数据 或 超出 范围 ):</script>"; 
} 
} 
. 
力 秘笈 心 法 


心 法 领悟 474: 使 用 mssql_data_seek0 函 数 的 注意 事项 。 
使 用 此 函数 时 要 注意 ， 参 数 row_number 是 从 0 开始 的 ， 所 以 若 在 本 实例 文本 框 中 输入 数字 1， 获 取 的 是 数 
据 库 中 的 第 2 条 数据 。 
高 级 


图 实例 说 明 


在 PHP 操作 MySQL 数据 库 中 ， 获 取 数 据 字 段 信息 使 用 mysql_ fetch_field 0 函数 ， 而 在 mssql 函数 库 中 操作 
SQL Server 数据 库 获取 数据 字段 信息 使 用 mssql_fetch_field0 函 数 。 在 本 实例 中 ， 通 过 mssql fetch_field0 函 数 获 
取 数 据 表 中 指定 字段 的 信息 ， 在 图 10.7 所 示 的 文本 框 中 输入 一 个 数字 值 ， 单 击 “ 确 定 ” 按 钮 ， 将 输出 如 图 10.8 
所 示 的 内 容 。 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<td class="0'>eolumn_source</td> 
<td class="0'>type</td> 
<td class="0 ">max_ length</td> 

<hr> 

<t> 
<td style="background: HFFFFFF"><?php echo iconv (‘gbk, ‘utf-8", $ts->name )?></td> 


}else{ 
?> 


心 法 领悟 475， 使 用 mssql_fetch_field0 函 数 的 注意 事项 。 
mssql_fetch field0 函 数 可 以 用 来 从 某 个 查询 结果 中 获取 字段 的 信息 。 如 果 没有 指定 字段 偏 移 量 ， 则 下 一 个 
尚未 被 mssql_fetch_field0) 函 数 获取 的 字段 将 被 提取 。 


me() 函 数 获 取 字 段 名 称 


实例 476 Daten 丰 妇 页 


实例 说 明 


实例 475 中 通过 mssql_fetch_field0 函 数 返回 对 象 的 name 属性 获取 字段 的 名 称 , 下 面 将 介绍 在 mssql 函数 库 
中 专门 用 来 获取 字段 名 称 的 方法 。 运 行 本 实例 ， 在 文本 框 中 输入 一 个 有 效 的 字段 值 ， 单 击 “确定 ”按钮 ， 将 输 
出 如 图 10.9 所 示 的 页 面 。 


《pHp 开 友 实 路 宝典》 
《PHP 标准 教程 } 
《PhP 网 络 编程 宇 奥 》 
范例 室 抒 } 
| 世人 了 二》 
| 并 据 东 字 联 记 称 为 price 


10.9 利用 mssql_field_name0 函 数 获 取 字 段 名 称 


力 关键 技术 


本 实例 主要 应 用 mssql_field 次 下 之 入 的 名 称 , 其 语法 如 下 : 


string mssql field_name ( resource result, int ficld_ index 
该 函数 返回 指定 字段 索引 的 字段 名 。 做 result 必须 是 一 个 合法 的 结果 标识 符 ， 参 数 field_index 是 该 字段 
的 数字 偏 移 量 。 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 ， 首 先 创建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 执行 查询 语句 ， 并 通过 
while 语句 和 mssql fetch row0 函数 循环 输出 查询 结果 集中 的 数据 。 最 后 获取 表单 提交 的 数据 ， 应 用 
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PHP 开发 实例 大 全 (基础 卷 ) 
mssql field_ name() 函 数 获取 指定 字段 的 名 称 ， 其 代码 如 下 : 


<?php 


if(isset ($_POST [sub] ) { 
站 ($_POST [te] 一 "||$_POST [te] 一 "输入 数字 ") { 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 );</script>"; 
else 
: 人 ("Nd",$_ POST [te]) { 
if($_POST [te] > 4) { 
echo "<script>alert( 输 入 的 数字 超出 范围 ):</script>"; 


Jelse{ 
Srss = mssql ficld_name ( $rs, $_POST [te] ): 
} 
yelse{ 


echo "<script>alert( 您 输入 的 不 是 数字 ):</script>"; 
} 
?> 
<a> 
<td bgcolor="#FFFFFF"> 数 据 表 字段 名 称 为 </td> 
<td bgecolor="#FFFFFF" style="color: #FF0000"><?php echo $rss:?></td> 
<lt> 


?> 


图 秘笈 心 法 
心 法 领悟 476: 使 用 mssql_field_name(0) 函 数 的 注意 事项 。 


在 使 用 此 函数 时 ， 参 数 field_index 从 0 开始 。 例 如 ， 第 3 个 字段 的 索引 值 其 实 是 2， 第 4 个 字段 的 索引 值 
是 3， 依 此 类 推 。 


和 中 。 | 
趣味 指数 : 依依 请 弃 | 
图 实例 说 明 


从 结果 集中 获取 数据 的 方法 有 很 多 ， 本 实例 主要 讲解 利用 数据 对 象 输出 结果 集中 的 数据 。 运 行 本 实例 ， 
效果 如 图 10.10 所 示 。 


0HP 标 渣 鞭 程 》 
《pHp 网 给 编程 宝 些 ] 

《PP 葬 何 宝典 》 

《PRP 范 何 手 册 》 


10.10 通过 结果 集 对 象 输出 数据 


图 关键 技术 
mssql fetch_object0 函 数 从 结果 集中 获取 一 行 作为 对 象 ， 如 果 没 有 更 多 行 则 返回 FALSE， 其 语法 如 下 : 


object mssql_fetch_object ( resource result ) 
该 函数 和 mssql_fetch_array0 函 数 类 似 ， 只 是 返回 一 个 对 象 而 不 是 数组 ， 即 只 能 通过 字段 名 来 访问 数据 ， 而 
不 是 偏 移 量 数字 是 合法 的 属性 名 ) 。 
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图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 


(2) 创建 index.php 文件 ， 包 含 数 据 库 连接 文件 ， 通 过 mssql_ query0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_object0 函 数 循环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 


<Iphp 
while ( $rst = mssql fetch object (S$rs)){ 
?> 


<t> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->id ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->bname ): ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->price ):?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk"."utf-8",Srst->date):?></td> 

<l> 

php 
} 


We 


国 秘笈 心 法 


心 法 领悟 477: 使 用 mssql_fetch_object0 函 数 的 注意 事项 。 


高 级 | 
实例 478 起 味 指数 : 页 机 页 
国 实例 说 明 


实例 477 中 讲解 了 通过 结果 集 对 象 输出 数据 ， 下 面 将 通过 另外 一 个 函数 将 结果 集 以 数组 的 形式 输出 。 运 行 
本 实例 ， 结 果 如 图 10.11 所 示 。 


Se 


Pe 于 
Tsonnnns 


《PHP 开 发 拓 战 字典 
《PHP 标 准 教程 》 
《PHP 网 站 编程 宝典 》 
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10.11 通过 结果 集 数 组 输出 数据 


图 关键 技术 


本 实例 主要 应 用 mssql_fetch_assoc0 函 数 ， 从 结果 集中 获取 一 行 作 为 关联 数组 。 如 果 没 有 更 多 行 则 返回 
FALSE， 其 语法 如 下 : 


array mssql_fetch assoc ( resource result id ) 


参数 result id 为 指定 的 结果 集 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 


(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssql query0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_assoc0 函 数 循 环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 


Ca 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


include_once ("conn.php"): 
Srs =mssql_query ( "select + from tb_demo10" ); 


<table width="580px" bgcolor="#FC8C7E"> 
<tr> 


<td style="color: #FFFFFF; text-align: center"> 图 书 ID</td> 
<td style="color: #FFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: 二 FFFFF; text-align: center> 出 版 日 期 <td> 
<lo> 


while ( Srst= mssql fetch assoc ( $rs )){ 
?> 


<tr> 


| hk, ‘utf8, Sta 2><hd> 
td style="background: "Si 


Srst [price] ); 2></td> 
Ed #FFFFFF"><?php echo iconv ( 'gbk' 二 人 ?><ltd> 


?> 


国 秘笈 心 法 


心 法 领悟 478: 使 用 mssql_fetch_assoc0 函 数 的 注意 事项 。 
由 于 该 函数 返回 的 是 一 个 关联 数组 ， 所 以 在 获取 数组 中 的 元 素 时 必须 使 用 字段 名 称 作 为 数组 的 索引 ， 同 时 


还 要 注意 ， 其 数组 的 索引 是 区 分 大 小 写 的 。 


实例 479 


图 实例 说 明 


如 果 用 户 只 想 查看 用 户 名 或 者 只 想 查看 单一 的 一 项 数据 ， 程 序 员 就 没有 必要 在 与 数据 库 的 交互 中 取得 一 行 


数据 ， 只 需要 从 数据 库 中 取得 单一 字段 信息 即 可 。 本 实例 通过 函数 mssql_result0 实 现 获 取 结果 数据 ， 运 行 结果 


如 图 10.12 所 示 。 

HP 开 发 实 歧 宝 鼻 》 

《PHP 标 准 教 程 》 

{PP 同 给 坊 程 主 共 》 

《48 区 介 宇 典 》 

《p99 区 说 手 册 》 

图 10.12 返回 结果 集中 的 单元 内 容 
图 关键 技术 
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本 实例 的 关键 点 是 如 何 运 用 mssql resultO 函 数 返回 结果 集中 的 单元 内 容 ， 其 语法 如 下 : 


string mssql_result ( resource result int row. mixed ficld ) 
参数 说 明 : 
resource result: 结果 集 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


图 关键 技术 
获取 指定 字段 的 长 度 应 用 的 是 mssql_field_length0 函 数 ， 其 语法 如 下 : 


int mssql_field length ( resource result, int ficld_offset ) 
参数 说 明 : 

resource result: 结果 集 。 

int field_offset， 字段 数 。 


图 设计 过 程 

(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 

(2) 在 index.php 文件 中 创建 form 表单 ， 提 交 指 定 要 查询 的 字段 值 并 且 将 数据 提交 到 本 页 。 

(3) 在 index.php 文件 中 包含 数据 库 连 接 文件 ， 执 行 查询 语句 完成 数据 表 中 数据 的 循环 输出 ， 并 对 表单 中 
提交 的 值 进行 判断 ， 如 果 符 合 要 求 ， 则 应 用 mssql_field_length0 函 数 获取 表单 提交 的 字段 的 长 度 值 并 且 输 出 ,其 


关键 代码 如 下 : 


<?php 
include_once ("conn.php"); 
S$rs = mssql._query ( "select * from tb_demo10" ); 
和 


<table width="580px" bgcolor="#FEF1BA"> 
<tr> 
<td style="color: #FFFFFF: text-align: center"> 图 书 ID</td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: 二 FFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: #EFFFFF; text-align: center"> 出 版 日 期 <td> 
<la> 


<?php 
if 人 isset($_ POST [sub] ) { 
Srss = mssql_ficld_length ( Srs, $_POST [select] ); 
echo "<font size=+l' color-red> 字 段 长 度 为 " . Srss . "</font>"; 
} 
while ( $rst= mssql_fetch row ( $rs )) { 
> 


<tr> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, utf-8', Srst [1] ): 2></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', utf-8', Srst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', Srst 3] ); ?></td> 


<?php 
} 


> 


国 秘笈 心 法 


心 法 领悟 480: 获取 数据 表 中 指定 字段 的 类 型 。 
在 mssql 函数 库 中 ， 不 但 可 以 获取 到 数据 表 中 指定 字段 的 名 称 、 长 度 、 定 位 指针 位 置 ， 而 且 可 以 获取 到 字 
段 的 类 型 ， 其 应 用 的 是 mssql field typeO 函 数 。 


rr ed 


力 实例 说 明 
通过 上 面 的 实例 ， 相 信 读 者 已 经 掌握 了 如 何 利用 函数 获取 字段 的 长 度 。 下 面 将 讲解 如 何 利用 函数 获取 指定 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 《基础 卷 ) 


心 法 领悟 481: SQL Server 数据 库 中 的 字段 类 型 。 


SQL Server 数据 库 中 的 数据 类 型 与 MySQL 数据 库 中 的 数据 类 型 有 所 不 同 ，SQL Server 中 的 字段 类 型 包括 
int、real、string、blob 、date 等 。 


高 级 | 


趣味 指数 : 依 请 请 坪 | 


实例 482 


力 实例 说 明 


在 SQL Server 数据 库 中 ， 取 得 结果 集中 的 字段 数目 其 实 与 操作 MySQL 数据 库 大 同 小 异 。 下 面 就 来 讲述 如 
何在 SQL Server 数据 库 中 取得 结果 集中 的 字段 数目 ， 运 行 结果 如 图 10.15 所 示 。 


NS 有 


当前 数据 表 字 级 臻 日 为 4 


《PHP 开 发 实 成 宝典 》 

《PAP 标准 教程 

《PKP 同 络 编程 空 典 》 

《PHP 范 例 宝典 》 

《PHP 范 例 手册 》 468 元 2010/ 八 月 /1 0: 00 


10.15 ”获取 结果 集 的 字段 数目 


力 关键 技术 
获取 结果 集 的 字段 数目 主要 应 用 mssql_num_fields0 函 数 ， 其 语法 如 下 ; 


int mssql_num fields( resource result ) 


参数 resource result 指 结果 集 。 
看 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql_connect() 函 数 连接 SQL Server 数据 库 服 务 器 ， 然 后 通过 mssql_ 
select_db0 〇 函数 连接 db_database10 数据 库 ， 其 代码 如 下 : 
< 
=mssql_connect("localhost","sa","") or die ("连接 SQL Server 时 发 生 错误 
mssql_select_db("db_database10",$conn) or die ("连接 数据 库 发 生 错 误 "); 
> 


(2) 创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssql_query0 函 数 执行 查询 语句 ， 应 用 
mssql_num fields() 函 数 获取 查询 结果 集中 总 的 字段 数 , 并 且 通 过 while 语句 和 mssql_fetch_row0 函 数 完成 查询 结 
果 集 中 数据 的 循环 输出 ， 代 码 如 下 : 

<?php 


include_once ("conn.php"); 
Srs = mssql_query ( "select * from tb_demo10" ): 
if($_GET[id]—D){ 

Srss =mssql num ficlds ( Srs ); 

echo "<font size='+1' color='red> 当 前 数据 表 字段 数目 为 " . Srss . "</font>"; 
} 
> 

<table width="580px" bgcolor="#CCES87"> 

<tr> 
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<td style="color: #FFFFFF:; text-align: center"> 图 书 ID</td> 

<td style="color: 考 FFFFF: text-align: center"> 图 书 名 称 </td> 

<td style="color: 二 FFFFF: text-align: center"> 图 书 价格 </td> 

<td style="color: 证 FFFFF; text-align: center"> 出 版 日 期 </td> 
<t> 


<?php 
while ( Srst= mssql fetch row (S$rs)){ 
> 


<tr> 
<td style= background: #FFFFFF"><?php echo iconv ('gbk, ‘utf-8", Srst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk', ‘utf-8', Srst [1] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( gbk' ‘utf-8", Srst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk, ‘utf-8', Srst [3] ); ?></td> 
<t> 
sphp 
?> 


心 法 领悟 482: 扩展 知识 。 
与 mssql num fields(0) 函 数 格式 类 似 的 mssql_ num rows0) 函 数 ， 可 用 于 获取 数据 表 中 结果 集 的 记录 数 。 


高 级 


实例 483 趣味 指数 : 袜 食 食 伍 


实例 说 明 


在 实例 482 的 秘笈 心 法 中 笔者 已 经 揭晓 ， 获 取 数据 表 中 数据 记录 数 应 用 的 是 mssql_num rows0 函 数 。 下 面 
将 通过 实例 向 读者 讲解 此 函数 的 具体 应 用 。 运 行 本 实例 ， 效 果 如 图 10.16 所 示 。 


| 《PAP 开发 实战 宝典》 元 2010/ 八 月 /31 0: 00 


| 《PP 标准 教程》 元 2010/ 八 月 1731 000 
《PHP 网络 蝙 吉 宝典 》 了 玩 20101 八 月 /31 0: 00 

元 20107 人 入 月 /31 0: 00 
20107 作 月 /31 0: 00 


10.16 ”获取 数据 表 中 数据 的 记录 数 


力 关键 技术 
本 实例 主要 应 用 mssql_num_rows0 函 数 实现 获取 数据 表 中 数据 的 记录 数 ， 该 函数 的 语法 如 下 : 


int mssql_ num rows (resource result ) 


参数 result 为 查询 结果 集 。 
图 设计 过 程 

创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 类 ， 完 成 与 db_database10 数据 库 的 连接 ， 循 环 输出 数据 表 中 的 
数据 ， 当 单 击 “获取 总 数量 ”按钮 时 ， 输 出 数据 表 中 总 的 记录 数 ， 代 码 如 下 : 

[en include_once("conn.php"); // 包 含 数据 库 连接 文件 


Srs = mssql_ query("select * from tb_demo10"): 
> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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力 设计 过 程 


创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 类 ， 对 类 进行 实例 化 操作 ， 完 成 与 db_database10 数据 库 的 连接 
并 循环 输出 数据 表 中 的 数据 ， 当 单 击 “ 释 放 结果 内 存 ” 超 链接 时 ， 执 行 释放 结果 集 的 操作 ， 代 码 如 下 : 
Ei include_once("conn.php"); // 包 含 数据 库 文件 


Sms = new Mssql("localhost"."sa",""."db_database10"); /实例 化 对 象 
Srs =mssql_query("select * from tb_demo10"): 


while($rst = mssql_feteh_row($rs){ /循环 输出 
?> 
<t> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',$rst[0]):?></td> 

td bgeolor="#FFFFFF"><?php echo iconv('gbk',utf-8',$rst[1]):?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk',‘utf-8',$rst[2]):?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',Srst[3]):?></td> 
< 


} 
if($_GET[d] — D{ 

Sms -> free_result($rs); /释放 结果 集 
} 


力 秘笈 心 ; 
心 法 领悟 484: 详解 mssql_free_result0 函 数 。 


mssql_free_result0 函 数 将 释放 所 有 与 结果 标识 符 result 相关 联 的 内 存 , 仅 需 要 在 考虑 到 返回 很 大 的 结果 集 时 
会 占用 较 多 内 存 时 调用 ， 在 脚本 结束 后 所 有 关联 的 内 存 都 会 被 自动 释放 。 


站 ee Od 机 
实例 485 5 趣味 指数 : 食 食 三 食 


力 实例 说 明 


在 程序 运行 结束 后 ， 不 但 要 释放 结果 内 存 ， 还 要 关闭 与 数据 库 的 连接 以 节省 系统 资源 。 运 行 本 实例 ， 单 击 
“关闭 连接 ” 超 链接 将 析出 提示 ， 运行 结果 如 图 10.18 所 示 。 


20L0/ 八 月 /3 0:00 
719 元 501W 入 月 / 红 0: 00 
1 玩 TAY AT) 


《PHP 开 发 安 小 宝 热 》 

《PAP 标准 教程 》 
《PHP 网 络 编 程 宝 积 》 

《PH 范例 室 禹 》 
《PHP 苑 例 手册 》 


图 10.18 关闭 与 数据 库 的 连接 


力 关键 技术 
本 实例 主要 是 通过 编写 数据 库 类 并 通过 对 象 句柄 调用 mssql_close0 函 数 ， 实 现 关闭 数据 库 连接 的 操作 。 其 
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加 载 中 
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Server 数据 库 的 连接 ， 其 中 通过 两 种 方法 连接 数据 库 ， 即 通过 mssql_ connectO 函 数 实现 与 数据 库 的 暂时 连接 、 
通过 mssql pconnectO 函 数 实现 与 数据 库 的 永久 连接 。Mssql 类 的 代码 如 下 : 


<php 
class Mssql{ 
var $host; 


public function __construct($host, Suser, Spwd,$conn){ /构造 函数 
Sthis -> host = $host 
Sthis -> user = $user; 
Sthis > pwd = $pwd; 
Sthis -> conn = $conn; 
Sthis -> connect|; 
} 
public function connectO{ 
这 Sthis -> conn 一 "pconn"){ 
Sthis -> conn = mssql pconnect($this -> hostSthis -> user.S$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建 立 永 久 连 接 );</script>"; 
yelse{ 
Sthis -> conn = mssql connect($this -> host,$this -> user.S$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建立 暂时 连接 ):</script>"; 
} 
} 
} 
> 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 编 写 数据 库 连接 类 ， 其 完整 代码 请 参考 关键 技术 中 的 内 容 。 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 提 交 连 接 数据 库 所 使 用 的 方式 。 然 后 包含 数据 库 连接 类 ， 执 行 
类 的 实例 化 操作 ， 并 调用 connect0 方 法 完成 与 数据 库 的 连接 ， 其 关键 代码 如 下 : 


<?php 
include_once("conn.php"): // 包 含 数据 库 连 接 类 
iflisset($_POST[sub]){ /判断 按钮 是 否 被 单 击 
if($_POST[select] — ""){ 1/ 判断 下 拉 列 表 框 内 容 
echo "<script>alert( 请 选择 连接 方式 ):</seript>";: 
jelsef 
Sms = new Mssql("localhost"."sa"."",$_POST[select]): /实例 化 对 象 
} 
} 
eg 
图 秘笈 心 法 


心 法 领悟 486:， 对 两 种 连接 方式 的 选择 。 

永久 连接 和 暂时 连接 从 功能 上 说 都 可 以 实现 与 数据 库 的 连接 操作 。 至 于 如 何 选择 ， 一 般 都 是 程序 员 的 个 人 
爱好 问题 。 笔 者 喜欢 用 暂时 连接 的 方式 ， 虽 然 在 操作 完 数据 库 后 须 及 时 关闭 与 数据 库 的 连接 ， 但 是 在 结构 上 较 
为 鲜明 。 


高 级 | 
趣味 指数 : 下 去 友 坟 友 | 


实例 487 


力 实例 说 明 


在 实际 Web 开发 过 程 中 ， 无 论 是 前 台 还 是 后 台 经 常会 用 到 向 数据 库 中 添加 信息 这 一 模块 ， 如 果 所 用 之 处 
都 要 重复 编写 代码 ， 这 会 使 整个 项 目的 代码 重用 率 大 大 降低 。 为 了 克服 上 述 缺陷 ， 可 以 通过 一 个 数据 信息 添加 
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类 来 实现 某 项 目 中 的 所 有 信息 的 添加 工作 。 运 行 本 实例 ， 图 书 添加 页 面 及 查看 图 书信 息 页 面 分 别 如 图 10.20 和 
10.21 所 示 ， 首 先 在 图 10.20 所 示 的 表单 中 输入 某 图 书 的 信息 ， 单 击 “ 添 加 ”按钮 即 可 将 图 书信 息 添加 到 数 
据 库 中 ， 同 时 可 以 在 图 10.21 所 示 的 页 面 中 查看 所 有 已 经 添加 的 图 书信 息 。 


| 
出 版 和 :|[ wa 明日 了 技 
放 考 :上 人 -得 提 革 开 妇 元 主 于 们 ) 本 日 R 技 
:| [EEC 了 EE TT 


EE | 加 加 加 
图 10.20 添加 图 书信 息 图 10.21 浏览 图 书信 息 


力 关键 技术 


本 实例 的 关键 是 如 何 编写 通用 的 添加 信息 类 ， 其 实现 的 基本 原理 是 : 通过 构造 函数 对 要 执行 的 SQL 语句 进 
行 初始 化 ， 这 样 即使 表 中 的 字段 数目 不 同 也 可 以 实现 将 图 书信 息 添加 到 数据 库 中 ，addbook 类 的 代码 如 下 : 


<php 

class addbook { 

private $add_sql; // 定 义 私有 变量 

public function __construct($x) { /定义 构造 函数 
Sthis->add sql= Sx; // 为 变量 赋值 

} 

public function add0 { // 定 义 添加 数据 的 方法 


include_once ("conn.php"); 
if (@mssql_query ( $this->add sql, Sconn )) { 

echo "<script>alert( 新 书 添加 成 功 !);history.back0:</script>"; 
}else{ 

echo "<seript>alert( 新 书 添加 失败 !"):history.back0:</seript>"; 
} 


} 

人 =$ POST [bookname]: 

S$auto =$_POST [auto]: 

Spub =$_POST [pub]; 

S$pubtime = $_POST [pubtime]: 

$sql = "insert into tb demo08(bookname.auto.pub.pubtime)jvalues('S$bookname'.$auto'.Spub''Spubtime)": 

Sadbook = new addbook ( $sql ); 

Sadbook->add (); 

> 

该 类 定义 一 个 私有 的 数据 成 员 $add_sql 用 于 保存 传 入 该 类 的 查询 语句 ， 并 通过 构造 函数 construct0 实 现 对 
该 私有 成 员 的 初始 化 ， 最 后 定义 该 类 的 成 员 函 数 add0 执 行 添加 操作 。 
力 设计 过 程 

(1) 新 建 conn.php 文件 ， 完 成 与 数据 库 的 连接 。 

(2) 新 建 addbook.php 文件 , 创建 form 表单 提交 要 添加 的 图 书信 息 ,将 图 书信 息 提交 到 savebook.php 文件 
中 。 添 加 图 书信 息 的 页 面 效果 如 图 10.20 所 示 。 

(3) 创建 savebook.php 文件 ， 编 写 数据 添加 类 ， 定 义 addbook0 方 法 执行 数据 的 添加 操作 。 在 该 文件 中 完 
成 类 的 实例 化 操作 ， 并 通过 返回 的 对 象 调用 类 中 的 addbook0 方 法 , 根据 表单 中 提交 的 数据 定义 insert 添加 语句 ， 
最 终 执行 数据 的 添加 操作 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 

(4) 新 建 index.php 文件 ， 循 环 输出 数据 表 中 存储 的 图 书信 息 ， 其 关键 代码 如 下 : 


加 载 中 
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public function DeleteO{ // 定 义 删除 方法 
if(!$rs = @mssql_query($this -> sqD){ // 如 果 执行 删除 操作 发 生 错 误 
echo "<script>alert(SQL 语句 错误 ");</script>"; //JavaScript 提示 
jelsef 


echo "<script>alert(' 删 除 成 功 ):location href='index.php?id=1';</script>"; 
8 
} 
} 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 编 写 数据 库 连接 类 ， 完 成 与 SQL Server 数据 库 的 连接 ， 其 代码 如 下 : 


<?php 
class ConnDemo{ // 定 义 类 名 称 
var $host; // 主 机 名 称 
var $user; /用 户 名 称 
varS$pwd; /用户 密码 
var $db; /| 数据 库 名 称 
Var $conn; /连接 标识 符 
var $tb; /数据 表 名 称 
Public function __construct($host,$user, Spwd,$db,Stb){ // 构 造 函 数 
Sthis -> host = $host; 
Sthis -> user = $user; 
Sthis -> pwd = $pwd; 
Sthis -> db = $db; 
Sthis -> tb = $tb; 
Sthis -> conneetO: 
} 
public function conneetO{ 


S$this -> conn = $conn; 
Sthis -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd) or die ("Connect mssql false"); 
mssql select db($this -> db,$this -> conn) or die ("Connect Database false"): 
} 
} 


?> 
(2) 新 建 delete.php 文件 ， 编 写 数据 库 删 除 类 并 继承 数据 库 连接 类 ， 其 代码 如 关键 技术 中 所 示 。 
(3) 新 建 index.php 文件 。 首 先 创建 form 表单 ， 提 交 图 书 的 ID 值 作为 执行 删除 操作 的 条 件 。 然 后 包含 数 
据 删除 类 文件 ， 执 行 DeleteDemo 类 的 实例 化 操作 并 且 向 类 中 传递 参数 。 接 着 执行 查询 语句 ， 循 环 输出 数据 表 中 
的 数据 。 最 后 根据 form 表单 提交 的 值 ， 通 过 类 实例 化 返回 的 对 象 调用 Delete0 方 法 执行 删除 操作 ， 其 关键 代码 
如 下 : 


<?php 

include ("delete.php"): 

$dd = new DeleteDemo ( "localhost". "sa", "", "db_database10", "tb_demo09" );: 
if($_GET [id]="1") { 

Srst= mssql_query ( "select * from tb_demo09" ): 

?> 


<form action="" method="post"> 
<input type="text" size="10" name="text" value=" 输 入 ID 删除 " onfocus="this.value="" class="one" /> 
<input type="submit" name="sub" value="&nbsp:" class="two" /> 
</form> 
<table width="580px" bgcolor="#FA7672"> 
<tr> 
<td align="center"> 图 书 名 称 </td> 
<td align="center"> 作 者 </td> 
<td align="center"> 出 版 社 </td> 
<td align="center"> 出 版 时 间 </td> 
<ltr> 
<?php 
while ( Srstt = mssql_fetch_ row (Srst) ) { 
> 


<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo iconv ( ,gbk'. ‘utf-8', Srstt [0] ):?><ftd> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8", Srstt [11 ):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srstt [2] ):?></td> 
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<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', Srstt [3] ):7></td> 
</tr> 
Bo 


} 

if($_POST [sub]) { // 判 断 提 交 按 钮 的 值 
Ste =$_POST[text]; /| 获取 提交 的 人 
$dd -> SQL(Ste): /调用 SQL 方法 定义 delete 删除 语句 
$dd -> Delete0: // 调 用 Delete0 方 法 执行 删除 操作 


图 秘 稚 心 法 


心 法 领悟 488: 类 的 继承 。 
少数 面向 对 象 的 语言 (如 C++、Smalltalk 等 ) 支持 多 继承 ， 即 一 个 子 类 有 多 个 父 类 。 但 是 PHP 自身 不 支持 
多 继承 ， 只 支持 单 继 承 ， 即 一 个 子 类 只 有 一 个 父 类 。 


本 高 级 | 
实例 489 | 起 味 指数 : 贾 页 页 页 | 
图 实例 说 明 


实现 更 新 图 书信 息 类 与 删除 图 书信 息 类 大 同 小 异 ， 只 是 将 删除 图 书信 息 类 中 的 两 个 核心 方法 蔡 换 为 更 新 操 
作 的 方法 即 可 。 运 行 本 实例 ， 执 行 图 书信 息 的 更 新 操作 ， 其 运行 效果 如 图 10.23 所 示 。 


因 书 情 息 
选择 妥 更 新 的 字 发 名 个 国 书 名 入 但 作者 个 出 版 社 个 出 版 日 期 
a 


[rE EE 


0 人 月 /11 0: 00 


CRA 
0 入 月 11 0;00 


10.23 更 新 图 书 类 的 实现 


力 关键 技术 


更 新 图 书 类 UpdateDemo 同样 集成 数据 库 连 接 类 ConnDemo， 与 数据 库 删 除 类 的 唯一 不 同 之 处 是 在 SQL 方 
法 中 定义 的 是 update 更 新 语句 。UpdateDemo 类 的 代码 如 下 : 


class UpdateDemo extends ConnDemo{ /| 继承 抽象 类 

var $sql; // 定 义 变量 

public function SQL($Condition1,$Condition2.$id){ // 定 义 方法 拼接 字符 串 
Sthis -> sql = $sql: 
S$this -> sql = "update ".$this -> tb." set $Condition1='$Condition2' where id=$id"; // 拼 接 字 符 串 
return $this -> sql: 

public function updateO{ // 更 新 操作 方法 
if($result = mssql_ query(Sthis -> sqD){ 

echo "<script>alert( 更 新 操作 以 成 功 ):location href='index .php?id=1':</script>"; //JavaScript 提示 

jelsef 


echo "<script>alert(SQL 语句 发 生 错 误 );</script>"; 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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心 法 领悟 489: 抽象 类 。 
抽象 类 与 普通 的 类 在 形式 上 没有 太 多 的 差别 。 抽 象 类 中 必须 存在 至 少 一 个 抽象 方法 ， 其 好 处 在 于 被 其 他 的 
子 类 继承 时 可 以 选择 性 地 执行 其 中 的 一 个 或 多 个 抽象 方法 。 
入 页 码 跳 转 到 指定 页 高 级 | 
趣味 指数 : dodolol 


实例 490 


力 实例 说 明 

分 页 显示 模块 的 页 码 跳 转 方式 有 多 种 ， 比 如 单 击 页 码 跳 转 、 从 下 拉 列 表 框 中 选择 页 码 实现 跳 转 等 。 或 许多 
数 程序 员 已 经 熟悉 通过 函数 方式 实现 分 页 ， 而 本 例 将 介绍 如 何 通过 ADO 方式 操纵 SQL Server 数据 库 实现 分 页 
显示 。 熟悉 ASP 的 读者 可 能 会 发 现 , 采用 这 种 方式 实现 分 页 与 ASP 通过 记录 集 实现 分 页 的 方式 类 似 。 运 行 本 实 
例 ， 如 图 10.24 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 跳 转 的 页 码 ， 然 后 单 击 GO 按钮 ， 即 可 实现 页 码 跳 转 。 


aveestas 2007-126 who 56 
[baYAse+8 关 图 书 2007-12-6 who 56 

JIMAR 相 天 图 节 2007-12-6 Who 56 
evesstax 2007-126 who 6 
区 2007-12.6 who 

| 上 有 主题 406 个 吉 页 明示 5 个 第 1 责 /六 32 页 1234ww 加 | | 


图 10.24 输入 页 码 跳 转 到 指定 页 


图 关键 技术 


为 了 方便 操作 ， 本 实例 将 采用 GET 方法 提交 用 于 输入 页 码 的 表单 ， 这 样 做 的 目的 是 使 通过 单 击 页 码 实 现 的 
跳 转 与 通过 在 文本 框 中 输入 页 码 实现 的 跳 转 都 用 $_GET[] 进 行 接收 , 否则 还 得 单独 做 一 个 用 $_POSI[] 数 组 接收 提 


交 的 页 码 的 模块 。 通 过 form 表单 完成 页 码 跳 转 的 代码 如 下 : 
<form action="index.php" method="get" name="forml" id="form1"> 
<tr> 


<td width="30"> 
<div align="center"><input type="text" name="page" size="2" class="inputess" /></div> 
<ltd> 
<td width="40"> 
<div align="center"><input name="submit" type="submit" class="buttoness" value="GO" /></div> 

<ltd> 
</tr> 
</form> 

图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 ADO 连接 SQL Server 数据 库 ， 其 代码 如 下 : 

<2php 
Sconn=new com("adodb.connection"); /| 创建 记录 集 
Sconnstr="provider=sqloledb:data source=localhost:uid=sa:pwd=:database—db_database10"; /| 连接 SQL Server 数据 库 
$conn->open($connstr); // 返 回 连接 对 象 


> 


(2) 编写 代码 用 于 接收 查询 字符 串 的 值 〈 该 值 代表 要 跳 转 的 页 ) 并 实现 分 页 显示 ， 代 码 如 下 : 


加 载 中 
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for($i= 2 $1 <= $rs->pagecount; $i1++) { 
<a href="index.php?page=<?php ce 2>"><?php echo $i:7></a> 
<php 


jslse t 
for($i=1; $1<—4: $i+7) { 
<a href="index php?page=<?php echo ie echo $i;7></a> 
<Iphp 
<a href="index php?page=<?php 1) echo Spage + 1; else echo 1; ?>" tile=" 后 一 页 "><font face="webdings"> 8 
por echo S$rs->pagecount; ?>" title=" 尾 页 "><font face="webdings"> : <ffont></a> 
} 


?> 
</div> 
<td> 
</t> 
</table> 


图 秘笈 心 ; 


心 法 领悟 490， 表单 提交 的 两 种 方式 。 

提交 表单 可 以 采取 POST 和 GET 两 种 方式 ， 这 两 种 方式 的 区 别 是 : 使 用 POST 方法 提交 的 信息 在 地 址 栏 中 
不 显示 ， 并 且 用 $_POST[] 数 组 接收 提交 的 内 容 。 而 采用 GET 方法 提交 的 信息 在 地 址 栏 中 显示 ， 如 果 提 交 多 个 信 
息 ， 则 信息 之 间 用 “&” 连 接 ， 并 且 提 交 的 内 容 用 $_GET[] 数 组 进行 接收 。 


Ee RR 站 
起 呆 朱 才 ; 帘 页 宙 od 


力 实例 说 明 


通过 单 击 页 码 跳 转 到 指定 页 ， 是 众多 分 页 方式 中 应 用 最 广泛 的 一 种 ， 通 过 这 种 方式 可 以 浏览 某 一 模块 中 的 
所 有 信息 。PHP 操作 MySQL 数据 库 实现 分 页 显示 主要 通过 关键 字 limit 实现 ,但 limit 关键 字 只 是 MySQL 数据 
库 的 扩展 部 分 , 不 能 被 SQL Server 数据 库 识 别 ， 所 以 本 实例 将 采取 一 种 特殊 方式 实现 SQL Server 数据 库 信息 的 
分 页 展示 。 运 行 本 实例 ， 如 图 10.25 所 示 ， 通 过 单 击 图 中 页 码 超 链接 即 可 实现 不 同 页 之 间 的 跳 转 。 


| “指定 责 跳 对 | 


2007/+= 有 /6 0:00 who 56 


1sms 夫 相关 图 所 | 

| 日 和 技 出 版 的 VE 类 相 关 图 征 | 2007/+= 有 /5 0:00 器 90 
国 日 科技 出 版 的 cx 站 关 图 本 | Ehk 2 
TS | 四 7 
冉 日 和 技 出 的 C11 类 坦 < 轩 书 | 加 + 
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图 10.25 利用 et 函数 库 实现 指定 页 跳 转 


图 关键 技术 


本 实例 采用 mssql 函数 库 ， 通 过 面向 过 程 的 方式 实现 数据 的 分 页 输出 ， 其 基本 原理 是 : 在 获取 数据 表 中 总 
的 记录 数 后 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 从 而 实现 分 页 操作 ， 其 关键 代码 如 下 : 
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<?php 

include_once ("conn.php"); /包含 数据 库 连 接 文件 
$sql = mssql query ( "select * from tb_demo07 order by pubtime dese", Sconn ); /执行 查询 

$sqll = mssql_query ( "select count(*) as total from tb_demo07", $conn ): /统计 记录 数 

Sinfol = mssql fetch_array ( $sqll ); /获取 查询 结果 集 


Stotal = $infol [total]; 
if($_GET [page] —""||is numeric ($_GET [page] ) — false) { 


Spage =1; // 定 义 分 页 变量 
}else { 
Spage =$_GET [page]; 1/ 获取 当前 页 码 
} 
Spagesize = 5; // 定 义 每 页 显示 记录 数 


让 (Stotal % $pagesize — 0) { 

Stotalpage = $total / $pagesize; 
}else{ 

Stotalpage = ceil ( $total / $pagesize ); 


} 

和 = 

while ( $info = mssql fetch array ( $sql )) { /| 循环 输出 查询 结果 
证 (Si > $pagesize * (Spage - 1) && $i <= Spagesize * Spage) { 
> 


<tr> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="left"><?php echo iconv ( ‘gbk', utf-8', $info [title] ):?></div> 
<ktd> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $info [pubtime] ):?7></div> 
<ltd> 
<td height="25" bgeolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $info [pubuser] ):?7></div> 
</td> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( 'gbk’, utf-8", Sinfo [click] ); ?></div> 
<ltd> 
</t> 


<?php 


有 + 
} 


?> 
四 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 完成 与 SQL Server 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 包 含 数 据 库 连 接 文件 ， 查 询 指定 数据 表 中 的 数据 ， 并 且 统计 总 的 记录 数 ， 定 义 


分 页 变量 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 
(3) 创建 分 页 超 链接 ， 完 成 数据 的 分 页 显示 ， 其 代码 如 下 : 


<table width="754" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 

<td width="338" height="25"> 

<div align="left"> 共 有 主题 <?php echo $total:?> 个 &nbsp: 每 页 显示 <?php echo $pagesize:?> 个 &nbsp: 第 <?php echo $page:?> 页 / 共 <?php 
echo S$totalpage:?> 页 </div> 

<htd> 

<td width="346"> 

<div align="right"> 
<?php 
for($i= 1; $i<= Stotalpage: $i ++) { 

> 


<a href-"index php?page—<?php echo $i:7>"><?php echo $i:7></a> 
<?php 

1 

2> 


</div> 

<td> 

<td width="70">&nbsp:<ltd> 
<i> 
</table> 
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利用 这 种 方法 实现 数据 库 信息 的 分 页 输出 并 不 是 将 焦点 放 在 数据 库 中 ， 而 是 无 论 当前 显示 的 是 哪 一 页 都 从 
数据 库 中 提取 出 所 有 的 记录 。 


心 法 领悟 491: 分 页 原理 。 
在 本 实例 中 ， 只 显示 $pagesize*($page-1) 与 $i<=$pagesize*$page 之 间 的 记录 ， 通 过 接收 不 同 的 Spage 值 来 判 
断 当前 应 显示 哪 一 页 。 


10.3 SQL Server 数据 库 的 综合 应 用 


本 节 以 SQL Server 数据 库 为 后 台 支 持 ， 将 整个 网 站 的 制作 过 程 分 成 若干 模块 进行 逐一 讲解 。 


力 实例 说 明 


“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 应 用 框架 设计 ， 模 拟 编程 词典 软件 的 页 面 布局 ， 其 首页 的 设计 
效果 如 图 10.26 所 示 ， 其 中 包括 网 站 模块 导航 、 功 能 导航 条 、 内 容 树 状 导 航 、 内 容 展 示 区 和 滚动 导航 条 。 


内 容 树 状 导航 


图 10.26 “明日 编程 词典 一 一 在 线 体验 版 ”首页 


图 关键 技术 


“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 应 用 框架 设计 将 文件 分 配 为 如 下 所 示 。 
框架 主体 文件 :index.html、index.php。 
网 站 模块 导航 : pd_top.html、pd_top.php。 
内 容 树 状 导航 : pd_left.html、pd _left.php。 
功能 导航 条 : pd_title html、pd_title php。 
内 容 展 示 区 : pd_main html、pd_main php。 
滚动 导航 条 : pd_bottom.html、pd_bottom.php。 


回回 回回 罗 加 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 关键 技术 


网 站 模块 导航 中 包含 两 项 技术 : 
第 一 项 技术 : 通过 js 脚本 向 FLASH 中 传递 参数 。 
(1) 创建 js 脚本 文件 flash1.js， 定 义 向 FLASH 中 写 入 的 内 容 ， 其 代码 如 下 : 


function flash1 (mm) { 
var flash2="<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download macromedia.com/pub/shockwave/cabs/ 
flash/swflash.cabiversion=7,0,19.0" width="171" height="93">"; 
@ flash2+='<param id="swf" name="movie" value="images/bccd.swf?conn type="+mt">"; 
flash2+="<param name="quality" value="high">"; 
flash2+="<param name="allScriptAccess" value="always"/>'; 
flash2+="<param name="wmode" value="transparent'>': 
flash2+="<embed sre="images/bced.swf" width="171" a quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer'" 
type="application/x-shockwave-flash" wmode="transparent"></embed>" 
flash2+="</object>'; 
@ 。 documentwrite(flash2): 
也 


es 

ER 代码 导读 
@ param id="swf': 在 swf 的 url 中 传递 参数 值 。 
@ document.write: 执行 写 入 操作 。 


(2) 在 FLASH 元 件 中 通过 on(release) 方 法 获取 传递 的 参数 值 ， 并 执行 超 链 接 。 


加 ”通过 this.loaderinfo.parameters["conn_ type"] 获 取 传 递 的 参数 值 ， 代 码 如 下 : 
var type=this.loaderinfo.parameters["conn_type"]: 
FLASH 中 的 编辑 效果 如 图 10.30 所 示 。 


| 呵 :志明 局 友 归 
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10.30 通过 变量 传递 参数 
回 “” 通过 getURL0 方 法 执行 超 链 接 ， 代 码 如 下 : 
getURL("pd_left.php?conn_id=20510111&table_name=study&class_type= 从 零 开 始 &conn_type=type", "leftwindow", "GET"); 
FLASH 中 的 编辑 效果 如 图 10.31 所 示 。 


[oetURL; 通知 We 济 虑 和 定 位 到 笑 室 的 LRL 
101118kade neve=stucy ciess hee= 从 零 开 好 Derm jrve=lyte ] 口 ass 


驯 :后 
第 3 了 行 getURLU pd Ef Php5conn d- e10111tabe name-stdydass tyoe- 从 志和 conn type-type, "eftwindow", GET 


图 10.31 通过 getURL 执行 超 链接 


(3) 在 本 程序 使 用 的 FLASH 中 创建 3 个 元 件 ， 分 别 对 应 入 门 、 开 发 和 应 用 3 个 模块 。 
元 件 1 的 脚本 代码 如 下 : 


(release) { 
二 Joaderinfo .parameters["conn_type"]: 
getURL("pd left.php?conn id-20510111&rtable_name=study&class_ type= 从 零 开 始 &conn type=type". "leftwindow", "GET"): 
} 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
元 件 2 的 脚本 代码 如 下 : 


on (release) { 

var type=this.loaderinfo.parameters["conn type"]: 

getURL("pd left.php?conn id=10121002&table_name=jszx&zclass_type= 技 术 中 心 &conn_type=type", "leftwindow", "GET"); 
} 


元 件 3 的 脚本 代码 如 下 : 

on (release) { 

var type=this.loaderinfo.parameters["conn type"]; 

ee lefi.php?conn id=10127105&table_ name=ymzx&zclass_type= 源 码 管理 &conn_type=type", "leftwindow", "GET"); 


第 一 项 技术 : 在 超 链接 中 应 用 onMouseOver 和 onMouseOut 事件 调用 JavaScript 脚本 中 的 方法 , 控制 鼠标 滑 


过 超 链接 图 片 时 的 样式 。 超 链接 的 设置 如 下 : 
<a href="pd_left.php?conn id=20510111&table_name=study&class_type= 从 零 开始 " target="leftwindow"><img 
sre="images/accidence/images_01.jpg" border="0" id="Imagel" onMouseOver="MM_swapImage('Imagel',",images/accidence/images_001.jpg',1)" 
onMouseOut="MM_swapImgRestore()" /></a> 


JavaScript 脚本 中 定义 的 方法 如 下 : 
function MM _preloadImagesO { //v3.0 
ES 
RN 
f(alilindexOf("#")!=0){ dMM plil=new Image: dMM pli++l].sre=afil:}} 


} 
function MM_swapImgRestore() { //v3.0 
varixa=documentMM sr for(i=0:a&&i<alength&&(x=a[i)&&x.oSrc:itH) x.sre=x.0Sre; 


} 
function MM._findObj(n, d) { //v4.01 
var piiix; 这 ld) d=document; if((p=n.indexOf("?"))>0&&parent frames length) { 
d=parent.frames[n.substring(p+1)].document: n=n.substring(0.p):} 
if(!(x=d[n])&&ed all) x=d.all[n]: for (=0:!x&&i<d forms.length:it+) x=d.forms[i][n]: 
for(i=0;!x&&d layersé&&i<d layers length:it+) x=MM_findObij(n,.d .layers[i]. document); 
if(Ix &é& d.getElementById) x=d.getElementById(n); retum x; 
} 
function MM._swapImage() {//v3.0 
var ij=0,x,a=MM_swapImage.arguments: document MM_sr=new Array: for(i=0:i<(alength-2):i+=3) 
if((x=MM_findObj(afi])!=null) {document. MM._srlj++ J=x: if(!x.oSre) x.oSre=x.sre; x.sre=a[i+2]:} 
} 


图 设计 过 程 
网 站 模块 导航 的 实现 主要 应 用 到 pd_top.html 和 pd_top.php， 以 及 js 文件 夹 下 的 flashl.js 和 topjs 文件 。 
(1) 创建 pd_top.php 文件 ， 其 主要 功能 是 定义 模板 变量 传递 参数 以 及 指定 模板 页 ， 其 代码 如 下 : 


< 

ee // 初 始 化 SESSION 变量 

require_once 'system/system.inc.php'; // 包 含 配置 文件 、 数 据 库 连 接 、 操 作文 件 
S$smarty->assign('conn_id',$_GET['conn_id"]); // 定 义 模板 变量 传递 参数 
SA /指定 模板 页 


(2) 创建 模板 页 pd_top.html。 首 先 通过 script 标签 调用 js 脚本 文件 夹 下 的 topjs 和 flashl.js 文件 。 然 后 定 
义 JavaScript 脚本 ， 执 行 flash10 方 法 ， 向 FLASH 中 传递 参数 值 。 最 后 根据 模板 变量 $conn_id 的 值 进行 判断 ， 从 
而 输出 不 同类 别 的 功能 模块 ， 并 为 输出 的 功能 模块 创建 超 链接 , 链接 到 pd_left.php 文件 ， 同 时 传递 相应 的 参数 ， 
其 关键 代码 如 下 : 
<html> 


<head> 
‘<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title>{$conn_type} 编 程 词典 </title> 
<lhead> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 
@<script type="text/javascript" sre="js/top.js"></script> 
@<script sre="js/flash1 js"></script> 
@<body onLoad="MM_preloadImages(images/criterion/images002 jpg’)"> 
<div style="padding-top:inherit width:100%; height: 93px: background:url(images/images_09.ipg):"> 
<div style="padding-top:inherit width:171px: height: 93px: float:left; "> 
Ee type= "textliavascript"> 

hashl( {$conn_type} 
水 
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请 耐心 等 待 或 者 刷新 重 试 
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如 果 是 应 用 类 ， 内 容 树 状 导航 中 默认 展示 的 是 “源码 管理 ”功能 模块 的 内 容 ， 如 图 10.34 所 示 。 


ae | 专业 出 版 专业 局 质 量 FE | 专业 出 版 专业 局 质 
图 10.33 开发 类 的 内 容 树 状 导航 图 1034 ”应 用 类 的 内 容 树 状 导航 
图 关键 技术 


在 内 容 树 状 导航 中 , 根据 网 站 模块 导航 中 传递 的 参数 值 , 控制 框架 中 topwindow( 网 站 模块 导航 )、leftwindow 
(内 容 树 状 导航 》 和 mainwindow〔 内 容 展示 区 ) 3 部 分 内 容 的 输出 ， 其 应 用 到 的 技术 如 下 : 
(1) switch 条 件 控制 语句 。 

在 pd_left.php 文件 中 ， 通 过 $_GET 方法 获取 网 站 模块 导航 中 参数 conn_id 传递 的 值 ， 并 将 该 值 作为 switch 
语句 执行 的 条 件 ， 与 case 关键 字 指 定 的 值 进行 判断 ， 如 果 相同 则 执行 相应 的 操作 ， 首 先 将 一 个 模板 页 赋 给 一 个 
模板 变量 。 然 后 通过 script 标签 向 topwindow 中 的 pd_top.php〔 网 站 模块 导航 〉 文件 传递 参数 。 最 后 通过 script 
标签 向 mainwindow 中 的 pd_main.php〔 内 容 展示 区 ) 文件 传递 参数 ， 其 关键 代码 如 下 : 

Pp 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 中 指定 的 值 相同 ， 如 果 相同 ， 则 执行 相应 的 操作 


#/ 
switch($_GET[conn id]){ 


ease "20510111": // 指 定 关键 字 
include ‘accidence.php'; // 包 含 文件 
S$smarty->assign('phtml','accidence.html'); // 将 模板 文件 的 名 称 赋 给 模板 变量 


/通过 seript 脚本 向 指定 的 文件 中 传递 参数 
echo "<script>parent topwindow .location href='pd_top.php?conn_id=20510111';</script>"; 
echo "<script>parentmainwindow ,location href='pd_main.php? conn_id=20510111';</seript>"; 
break; // 跳 出 循环 
/省 略 了 部 分 代码 
(2) 通过 Smarty 中 的 include 函数 在 当前 模板 中 包含 其 他 模板 文件 。 
在 switch 语句 中 ， 将 指定 的 模板 文件 名 称 赋 给 一 个 模板 变量 phtml， 此 时 在 内 容 树 状 导航 的 模板 文件 
pd_lefthtml 中 ， 获 取 模 板 变 量 phtml 传递 的 值 ， 并 且 将 该 值 作为 Smarty 中 include 函数 包含 的 模板 文件 。 内 容 


树 状 导航 模板 文件 pd_left.html 的 关键 代码 如 下 : 
<script language="javascript" sre="js/leftjs"></script> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 


<div style="width: 10096: height: 10096: padding-left:Spx: padding-top:5px:"> 
{include file=$phtml} 


(3) 通过 Smarty 中 的 注册 模板 函数 读 取 指 定 文件 。 
(4) 通过 Smarty 中 的 count_characters 和 truncate 方法 统计 和 截取 字符 串 。 

在 入 门类 、 开 发 类 和 应 用 类 的 树 状 导航 菜单 中 ， 都 应 用 了 Smarty 中 的 count_ characters 和 truncate 方法 ， 对 
指定 字符 串 的 长 度 进行 统计 和 截取 ， 从 而 判断 数据 属于 几 级 菜单 。count_characters 和 truncate 方法 在 本 项 目 中 
应 用 的 关键 代码 如 下 : 

{if $subject[id12].Slcount_characters—"12" && $subject[id12].Sltruncate:8:""—S$subject[id].8 } 

上 述 代 码 取 自 developer.html 模板 文件 。 

力 设计 过 程 


在 内 容 树 状 导航 概述 中 已 经 了 解 ， 内 容 树 状 导航 除了 包含 pd_ leftphp 和 pd_left.html 文件 外 ， 还 包含 入 门 、 


jy 
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开发 和 应 用 3 类 中 的 6 个 文件 。 

(1) 在 pd_leftphp 文件 中 ,获取 网 站 模块 导航 超 链接 中 传递 的 参数 值 ， 并 且 将 参数 值 赋 给 SESSION 变量 ， 
通过 switch 语句 对 传递 的 参数 值 进行 判断 ， 从 而 控制 框架 中 topwindow〔 网 站 模块 导航 ) 、leftwindow (内 容 树 
状 导 航 》 和 mainwindow〈 内 容 展 示 区 ) 3 部 分 内 容 的 输出 ， 其 关键 代码 如 下 : 


<?php 

session_start(); // 初 始 化 SESSION 变量 

if($_GET[conn_idj—"" and $_GET[table name]—""){ // 判 断 conn_id 和 table_name 的 值 为 空 
$_SESSION[conn id]j="20510111"; /设置 初始 值 

$_SESSION[table_name]="study"; // 设 置 数据 库 名 称 

$_SESSION[class_type]=" 从 零 开 始 "; /设置 功能 模块 

Jelse{ /如 果 不 为 空 ， 则 直接 将 它们 的 值 赋 给 SESSION 变量 


S$_SESSION[conn idj-$_GET[conn id]: 

$_SESSION[table_ name]=$_GET[table_name]: 

$_SESSION[class_type]=$_GET[class_type]: 

} 

require 'system/system.ine.php'; // 包 含 数据 库 连接 、 操 作 方法 和 Smarty 的 配置 方法 
让 


switch 条 件 控制 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 
中 指定 的 值 相 同 ， 如 果 相 同 ， 则 执行 相应 的 操作 

4 

switch($_GET[conn id]){ 


case "20510111": // 指 定 关键 字 
include ‘accidence.php'; /包含 文件 
Ssmarty->assign(phtmlvaceidence html9; // 将 模板 文件 的 名 称 赋 给 模板 变量 
// 通 过 seript 脚本 向 指定 的 文件 中 传递 参数 


echo "<script>parent.topwindow.location.href='pd_top.php?conn_id=20510111';</script>"; 
echo "<script>parent.mainwindow.location. href='pd_main.php?conn_id= 20510111';</script>"; 
break; // 跳 出 循环 
ease "20610111": 
include ‘accidence.php' 
$smarty->assign('phtml','accidence.html); 
echo "<script>parent mainwindow location href='pd_main.php?conn_id= 26010111';</script>"; 
break; 
/| 省略 了 部 分 代码 
default: 
include 'accidence.php'; 
$smarty->assign('phtml','accidence.html"); 
echo "<script>parent.topwindow.location.href='pd_top.php?conn_id=20510111';</script>"; echo 
"<script>try {parent.mainwindow .location.href='pd_main.php?conn_id= 20510111';}catch(e) {}</script>"; 
break; 


} 
Ssmarty->display('pd_left html); /指定 模板 页 
?> 


(2) pd_lefthtml 模板 文件 中 输出 的 内 容 由 switch 语句 中 定义 的 模板 变量 phtml 的 值 决定 ， 在 pd_left.html 
文件 中 应 用 Smarty 中 的 include 函数 包含 由 phtml 指定 的 模板 文件 ， 其 关键 代码 如 下 : 


<script language="javascript" sre="js/left.js"></script> 

<link rel="stylesheet" type="text/ess" href="css/link.css"></link> 

<div style="width: 100%; height: 100%; padding-left:Spx; padding-top:5px:"> 

{include file=$phtml} 

</div> 

(3) 定义 developer.php 文件 ， 获 取 SESSION 变量 中 传递 的 值 ， 执 行 查 询 操 作 ， 并 将 查询 结果 赋 给 指定 的 

模板 变量 ， 注 册 模 板 函 数 ， 读 取 指定 的 文件 ， 其 代码 如 下 : 

<?php 


i($_SESSION[conn_id] 一 "" and $_SESSION[table_name] 一 ""){ ”// 判 断 SESSION 变量 的 值 是 否 为 空 

Sconn_id="10127105"; // 如 果 SESSION 变量 的 值 为 空 ， 则 直接 为 变量 赋值 
Stable_name="ymzx": 

Sclass_type=" 源 码 管理 "; 

yelse{ /如 SESSION 变量 不 为 空 ， 将 SESSION 的 值 赋 给 指定 的 变量 
S$conn_id=$_SESSION[conn id]: 

Stable_name=$_SESSION[table_name]: 

Sclass_type=$_SESSION[class_type]: 

} 


S$smarty->assign("conn_id",$conn id): /设置 模板 变量 
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$smarty->assign("class type",$class_type): /设置 模板 变量 
function unHtml($params) { 1/ 创建 自 定义 函数 
extract($params):; // 将 数组 中 的 数据 转换 到 变量 中 
if(strlen($text)—12){ // 判 断 字符 串 的 长 度 是 否 等 于 12 
S$str =is_file("files/". $text.".htm"); 1/ 判断 指定 的 文件 是 否 存在 
Sstrl =is_file("files/". $text.".exe"); // 判 断 指定 的 文件 是 否 存在 
if(Sst){ // 如 果 文件 存在 
return "files/" $text.".htm"; // 返 回 文件 名 称 
yelse if($strD){ 
retum "files/" .$text.".exe"; /返回 文件 名 称 
jelsef 
return "files/1999.htm"; // 否 则 返回 一 个 新 的 文件 
. 
jelse if(strlen($text)—16){ // 判 断 字符 串 的 长 度 是 否 等 于 16 
Sstr =is_file("files/".$text.".htm"); // 判 断 指定 的 文件 是 否 存在 
if(Sst){ 
return "files/". $text.".htm"; /返回 文件 名 称 
jelseifSstrD{ 
Tetumn "files/" $text.".exe"; /返回 文件 名 称 
jelsef 
return "files/2000.htm"; /否则 返回 一 个 新 的 文件 
} 
, } 
$smarty->register_function("Util", "unHtml"); /注册 模板 函数 
if($conn_id 一 "10121002@10122105@10123105@10125105"){ 。 /判断 变量 的 值 
Sarray_id=explode("@",$conn_id); // 将 这 值 返回 到 数组 中 
Sarray_table=explode("@",$table_name); // 将 数据 表 名 称 的 值 返 回 到 数组 中 
for($i=0;$i<count($array_id):$i++){ /| 循环 读 取 数组 中 的 id 值 
// 执 行 查询 操作 
Srst[$i] = Sadmindb->ExecSQL("select * from $array_table[$i] where xxbh like ‘$array_id[$i]%",$conn); 
Sresult=array_merge($rst[0].Srst[1].$rst[2].$rst[3]): // 合 并 查询 结果 
S$smarty->assign('subject', $result); // 将 合并 的 查询 结果 赋 给 模板 变量 
jelsef 
/执行 查询 操作 
Srst = $admindb->ExecSQL("select * from $table_name where xxbh like 'Sconn id9o",Sconn): 
S$smarty->assign('subject',$rst); /| 将 查询 结果 赋 给 模板 变量 
> 


(4) 创建 developer.html 模板 文件 ， 通 过 section 循环 语句 读 取 模板 变量 中 存储 的 数据 ， 并 且 应 用 让 语句 进 
行 判断 ， 如 果 指 定 字符 串 的 长 度 是 8 个 字 节 ， 则 说 明 是 一 级 导航 菜单 ; 如 果 指 定 字符 串 的 长 度 是 12 个 字 节 ， 并 
且 其 前 8 个 字 节 与 一 级 导航 菜单 的 8 个 字 节 相同 , 那么 它 是 二 级 导航 菜单 ; 如 果 指 定 字符 串 的 长 度 是 16 个 字 节 ， 
并 且 其 前 8 个 字 节 与 一 级 导航 菜单 的 8 个 字 节 相 同 ， 其 前 12 个 字 节 与 二 级 导航 菜单 的 12 个 字 节 相同 ， 那 么 它 
是 三 级 导航 菜单 。 具 体 代 码 请 参考 光盘 中 内 容 。 


图 秘笈 心 法 


心 法 领悟 494: 使 用 pd_left.html 模板 文件 的 注意 事项 。 
在 pd_left.html 模板 文件 中 ， 必 须 载 入 leftjs 脚本 文件 和 link.css 样式 文件 ， 这 是 实现 树 状 导航 菜单 功能 和 
控制 页 面 属性 的 关键。 


实例 495 


趣味 指数 : 伍 食 福全 | 


力 实例 说 明 
内 容 展示 区 可 输出 内 容 树 状 导航 菜单 中 指定 标题 的 完整 内 容 。 如 果 指 定 标题 的 完整 内 容 不 存在 ， 则 输出 指 
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定 的 蔡 代 文件 ， 其 运行 效果 如 图 10.35 所 示 。 


入 门 开发 应 用 


四 人 要 Fi 


i 让 4 
昌国 册 囊 了解 ( 讽 频 ) 程序 员 的 工作 
《加 ts 程序 是 由 算法 、 站 各 序 设计 方法 、 计 算 机 本 寺 工 具 环 光度 ,我 们 全 从 事 程序 开 恬 、 维 护 的 专业 人 员 ， 从 为 程序 


设计 人 员 的 分 析 总 结 的 开发 方案 ， 来 编 

向 题 ， 程序 员 进 行 沟通 ， 来 修改 程序 ， 当 测试 通过 

步 的 成 果 。 ede 程序 员 完 成 的 工作 在 整 人 软件 开 发 过 得 中 起 兰 关 键 上 的 作用 ， 也 
ee 纺 S 人 RR. Te 下 面 是 一 个 软件 开发 的 流程 图 。 


~ 


员 。 在 开发 项 目 之 1 


一 个 简单 的 程序 实现 
日 国 了 解 开发 相关 的 几 个 | 
所 国生 序 员 的 成 上 之 路 


rs 
© 
mm / 
国 we miaf 卉 
[BB 
[ET a 
日 国 _m5 0 向 动 全 人 
国庆 过 开 几 芝 香 有 动 
日 国 wh 60 的 昌吉 开发 环 1 Rn 
EE | eo 


《全 入 记 由》 是 红字 习 的 者 帮 、 持 太 查 二 的 工具 、 也 动 与 灾 运 的 吉方 。 内 罕 胡 六 技术 、 项 目 、 方 案 、 神 码 ， 视 频 、 略 而 等 考 而 。 


图 10.35 内 容 展示 | 


内 


图 关键 技术 


内 容 展 示 区 中 完整 内 容 的 输出 ， 关 键 是 内 容 树 状 导航 菜单 中 标题 的 超 链接 值 的 设置 ， 该 值 是 从 注册 模板 函 
数 中 获取 的 。 也 就 是 说 在 注册 模板 函数 中 判断 指定 标题 的 完整 文件 是 否 存 在 ， 如 果 存 在 ， 则 输出 这 个 文件 ， 否 
则 输出 指定 的 蔡 代 文件 。 在 本 项 目 中 定义 3 个 注册 模板 函数 ， 其 功能 都 是 输出 指定 的 文件 ， 这 3 个 模板 文件 分 
别 存储 于 accidence.php、criterion.php 和 developer.php 中 。 


力 设计 过 程 
内 容 展示 区 只 包含 一 个 文件 pd_main php。 在 该 文件 中 判断 超 链 接 传递 的 参数 值 ， 并 根据 此 数值 包含 不 同 的 
替代 文件 ， 其 代码 如 下 : 


<?php 

//require_once 'system/system_inc.php': // 调 用 配置 文件 
JSsmarty->assign('conn_id'$_GET[conn id]): 

这 $_GET[conn id] 一 "20510111" or $_GET[conn_id]j="10121605"){ 。”// 判 断 超 链 接 的 id 值 


include_once("files/1999.htm"): /调用 指定 的 包含 文件 
}else{ 

include_once("files/2000.htm"): // 调 用 指定 的 包含 文件 
} 

> 


图 秘笈 心 法 

心 法 领悟 495: 关于 JavaScript。 

在 “明日 编程 词典 一 一 在 线 体验 版 ” 的 页 面 设计 中 应 用 了 很 多 JavaScript 代码 ， 其 中 包括 对 导航 栏 和 树 状 导 
航 栏 的 设计 。 如 比较 流行 的 JQuery 框架 即 是 业界 追捧 的 JavaScript 框架 ， 如 果 用 户 有 JavaScript 脚本 语言 的 基 
础 ， 可 以 利用 JQuery 框架 实现 本 实例 的 内 容 。 
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10.4 SQL Server 数据 库 的 安全 与 维护 
一 本 wo 
ri 1 
实例 
i | eed 
力 实例 说 明 
数据 库 在 使 用 一 段 时 间 后 ， 时 常会 出 现 因 删 除数 据 而 造成 的 空闲 空间 太 多 的 情况 ， aaa 
数据 库 文件 和 事务 日 志文 件 的 空间 ， 以 免 浪 费 磁盘 空间 。 当 
数据 库 中 没有 数据 时 , 可 以 直接 修改 数据 库 文件 的 属性 以 改 
变 其 占用 空间 ,但 当 数 据 库 中 有 数据 时 ， 这 样 操作 就 会 破坏 


其 中 的 数据 ， 因 此 需要 使 用 收缩 的 方式 来 缩减 数据 库 空间 。 
本 实例 实现 将 SQL Server 数据 库 | 的 未 使 用 空间 缩 为 服 查 王 hc-201905101638 GD se 51) |ab-astabasel0 | 0:00:00 有 行 了 硬 1 列 了 弦 才 


数据 库 大 小 的 10%。 在 查询 分 析 器 中 的 运行 结果 如 图 10.36 图 10.36 收缩 数据 和 日 志 
所 示 。 
图 关键 技术 


可 以 使 用 DBCC SHRINKDATABASE 命令 来 压缩 数据 库 。 
DBCC SHRINKDATABASE 语句 的 语法 如 下 : 
DBCC SHRINKDATABASE 
(database name [ , target_percent ] 
[,{NOTRUNCATE | TRUNCATEONLY } ] 
) 
参数 说 明 : 
database_name: 要 压缩 的 数据 库 名 称 。 
target_percent: 数据 库 压缩 后 ， 数 据 库 文件 中 所 要 的 剩余 可 用 空间 百分比 。 如 果 指 定 的 百分比 过 大 ， 超 过 
了 压缩 前 未 使 用 的 空间 所 占 的 比例 ， 则 数据 库 不 会 被 压缩 。 另 外 ， 压 缩 后 的 数据 库 不 能 比 数据 库 初 使 设 定 的 容 
量 小 。 
NOTRUNCATE: 在 数据 库 文件 中 保留 所 释放 的 文件 空间 。 如 果 未 指定 ， 将 释放 的 文件 空间 分 配给 操作 系统 。 
TRUNCATEONLY: 将 数据 库 文件 中 的 任何 未 使 用 的 空间 释放 给 操作 系统 ， 并 将 文件 收缩 到 上 一 次 所 分 配 
的 大 小 ， 从 而 减 小 文件 而 不 移动 任何 数据 ， 不 试图 重新 定位 未 分 配 页 的 行 。 选 择 此 项 后 ，target_percent 选项 将 
无 效 。 


国 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 查询 分 析 器 中 选择 要 连接 的 数据 库 为 db_database10。 
(3) 在 代码 编辑 区 中 输入 SQL 语句 : 


DBCC SHRINKDATABASE (model, 10) 

(4) 单 击 执行 按钮 时 ， 执 行 本 实例 ， 即 可 将 数据 库 压 缩 。 
国 秘笈 心 法 

心 法 领悟 496: 压缩 数据 库 。 


670 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 即 可 实现 数据 的 收缩 。 


国 秘笈 心 法 


心 法 领悟 497: 收缩 数据 与 压缩 数据 。 
在 笔者 看 来 ， 收 缩 数据 与 压缩 数据 在 功能 上 没有 什么 不 同 。 压 缩 数据 是 按 比 例 将 数据 的 物理 内 存 减 小 ， 而 
收缩 数据 是 根据 传 入 参数 将 数据 文件 的 大 小 减少 至 一 定 值 。 


实例 498 


力 实例 说 明 
在 网 站 开发 过 程 中 ， 


: 
i 


高 
趣味 指教 : 傅 博 二 禄 ; 


数据 库 一 般 都 保存 有 许多 重要 的 数据 信息 ， 这 些 数 据 的 丢失 将 会 带 来 很 严重 的 后 果 ， 


所 以 对 系统 数据 库 进行 备份 非常 重要 ， 这 样 可 以 在 数据 库 出 现 错 误 时 能 够 及 时 地 恢复 数据 库 。 本 实例 介绍 使 用 
SQL 语句 备份 SQL Server 数据 库 的 过 程 ， 并 使 SQL Server 在 完成 备份 的 20% 时 显示 备份 进度 信息 。 


图 关键 技术 


本 实例 使 用 BACKUP DATABASE 语句 ， 完 成 数据 库 、 差 异 式 或 文件 和 文件 组 的 备份 ， 其 简要 用 法 如 下 : 
BACKUP DATABASE { database_name | @database_name_var } 
TO < backup device >[ ,.n] 


[WITH 


[BLOCKSIZE = { blocksize | @blocksize_variable } ] 
[[,]NAME = { backup_set_name | @backup_set_name var } ] 


[[,] DESCRIPTION = 

] DIFFERENTIAL ] 
FORMAT | NOFORMAT ] 
{NOUNLOAD | UNLOAD } ] 


[[, 
[[,] 
[[,] 
[[,]RESTART] 
[IT.1 


{ text | @text_variable } ] 


STATS[=percentage 11 


BACKUP DATABASE 语句 参数 说 明 如 表 10.2 所 示 。 


表 10.2 BACKUP DATABASE 语句 的 参数 说 明 


参数 说 明 
设置 写 入 时 的 数据 区 块 大 小 。 此 值 通常 不 需 设置 ， 可 以 由 SQL Server 自行 决定 ， 但 如 要 将 备份 
BLOCKSIZE 数据 库 刻 录 到 光盘 上 ， 并 打算 用 光盘 进行 还 原 ， 则 需 将 此 值 设置 为 2048。 如 要 指定 磁盘 的 数据 
区 块 大 小 ， 必 须 搭配 FORMAT 参数 使 用 
NAME 表示 备份 结果 集 的 名 称 ， 其 长 度 不 超过 128 个 字符 
DESCRIPTION 描述 备份 设置 的 文本 ， 最 多 包括 255 个 字符 
表示 仅 备份 上 次 进行 完整 数据 库 备 份 以 来 数据 所 发 生 的 变化 ， 即 进行 差异 备份 。 差 异 备份 一 般 
DIFFERENTIAL 比 完整 备份 占用 更 少 的 空间 。 对 于 上 一 次 完整 备份 时 备份 的 全 部 单个 日 志 ， 使 用 该 选项 可 以 不 
必 再 进行 备份 
FORMATINOFORMAT | 设置 是 否 先 格式 化 磁盘 
NOUNLOADIUNLOAD | 设置 是 否 要 在 备份 完成 时 退出 磁盘 
指定 SQL Server 重新 启动 一 个 被 中 断 的 备份 操作 。 因 为 RESTART 选项 在 备份 操作 中 断 处 重新 
RESTART 启动 该 操作 ， 所 以 节省 了 时 间 。 若 要 重新 启动 一 个 特定 的 备份 操作 ， 要 重复 整个 BACKUP 语 
名 并 且 加 入 RESTART 选项 。 不 一 定 非 要 使 用 RESTART 选项 ， 但 它 具有 节省 时 间 的 优势 
STATS 表示 在 备份 完 某 一 百分比 数据 之 后 所 要 显示 的 信息 
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力 设计 过 程 


下 面 将 备份 db_database10 数据 库 ， 具 体操 作 步 又 如 下 : 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


BACKUP DATABASE db sql 
TO disk=E:MyDatadb sql 备份 -bak 


(3) 单 击 执行 按钮 站 ， 执 行 备份 。 备 份 后 的 db_database10 数据 
库 被 保存 在 E 盘 的 SQL Server Data 文件 夹 中 ， 如 图 10.38 所 示 。 


国 秘笈 心 法 图 10.38 备份 数据 库 文件 


心 法 领悟 498: 备份 数据 库 的 注意 事项 。 
笔者 在 讲解 MySQL 数据 库 备 份 时 已 经 说 过 ， 备 份 出 来 的 文件 虽然 已 经 经 过 加 密 处 理 ， 但 也 是 将 数据 信息 
以 近乎 明文 的 方式 展现 给 用 户 ， 存 在 一 定 的 风险 。 


oo 人 一 一 一 | 
9 趣味 指数 : 寅 让 福全 | 
图 实例 说 明 


本 实例 实现 的 是 在 创建 的 命名 备份 设备 上 创建 db_database10 数据 库 的 事务 日 志 备份 。 事 务 日 志 备份 仅 制作 日 志 
文件 的 复 本 。 日 志文 件 备份 本 身 不 能 用 于 还 原 数据 库 。 日 志文 件 在 数据 库 还 原 后 ， 可 将 数据 库 恢复 到 原始 的 故障 点 。 


图 关键 技术 


本 实例 应 用 的 技术 有 创建 备份 设备 和 应 用 BACKUP BLOG 语句 备份 事务 日 志 。 

1. 创建 备份 设备 

备份 设备 是 创建 备份 和 恢复 数据 库 的 前 提 条 件 ， 可 以 将 数据 库 、 事 务 日 志和 文件 备份 到 磁盘 和 磁带 上 。 设 
备 可 以 分 为 4 种 : 磁盘 设备 、 磁 带 设备 、 物 理 设 备 和 逻辑 设备 。 

磁盘 设备 、 磁 带 设备 和 物理 设备 在 备份 时 ， 只 要 选择 相应 的 设备 即 可 。 而 逻辑 设备 用 来 标识 物理 设备 的 别 
名 或 公用 名 称 ， 其 名 称 永久 地 存储 在 SQL Server 内 的 系统 表 中 。 使 用 逻辑 备份 的 优点 是 引用 名 称 简单 ， 例 如 ， 
逻辑 设备 名 称 可 以 是 mrsoft Backupfdw， 而 物理 设备 名 称 则 是 E:\SQL Server DatawmrosftMyBackup.bak。 


在 Transact-SQL 语句 中 ， 使 用 op - addumpdevice 系统 存储 过 程 创 建 备份 设备 ， 语 法 如 下 : 
sp_addumpdevice [ @devtype = ] ‘devict 
[ @logicalname = ] logical_ name' 、 
[ @physicalname = ] ‘physical_name’ 
[, {[ @entrltype = ] controller type 
|[ @devstatus = ] 'device_status' 


参数 说 明 ; 

device type: 备份 设备 的 类 型 。device_type 的 数据 类 型 为 varchar(20)， 没 有 默认 设置 ， 可 以 是 Disk〔 硬 盘 
文件 ) 、Pipe〈 命 名 管理 ) 或 Tape (磁带 设备 ) 。 

logicalname: 备份 设备 的 逻辑 名 称 , 该 逻辑 名 称 用 于 BACKUP 和 RESTORE 语句 中 , 其 数据 类 型 为 sysname， 
没有 默认 值 ， 并 且 不 能 为 NULL。 

physicalname: 备份 设备 的 物理 名 称 。 物 理 名 称 必须 遵照 操作 系统 文件 名 称 的 规则 或 者 网 络 设备 的 通用 命名 
规则 ， 并 且 必 须 包括 完整 的 路 径 。physical_name 的 数据 类 型 为 nvarchar(260)， 没 有 默认 值 并 且 不 能 为 NULL。 
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2. 用 BACKUP LOG 语句 备份 事务 日 志 

执行 BACKUP LOG 语句 备份 事务 日 志 ， 同 时 指定 要 备份 的 事务 日 志 所 属 的 数据 库 名 称 、 事 务 日 志 备份 将 
写 入 的 备份 设备 。 其 语法 格式 请 参见 实例 498 中 的 技术 分 析 。 

执行 完整 数据 库 备 份 或 差异 数据 备份 期 间 不 能 备份 事务 日 志 , 但 在 运行 文件 备份 的 同时 可 以 备份 事务 日 志 。 
另外 ， 下 列 情况 不 要 备份 事务 日 志 : 

(1) 在 由 于 事务 日 志 包 含 自 上 次 创建 备份 后 数据 库 所 发 生 的 更 改 ， 而 创建 了 数据 库 或 文件 备份 之 前 。 

(2) 事务 日 志 已 被 截断 。 此 时 如 果 要 备份 事务 日 志 ， 必 须 先 创建 数据 或 差异 数据 库 备 份 。 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 ， 创 建 一 个 名 为 mrsoft_Backupfdw 的 逻辑 磁盘 设备 ， 其 物理 路 径 为 


E:\SQL Server Data\mrosft\MyBackup.bak. 
SP_ADDUMPDEVICE 'disk',mrsoft_ Backupfdw’,' E:\SQL Server Data\mrosft\MyBackup.bak ' 


(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 运行 结果 如 图 10.39 所 示 。 
(4) 在 代码 编辑 区 中 输入 如 下 SQL 语句 ， 用 来 在 创建 的 命名 备份 设备 mrsoft_Backupfdw 上 创建 db_ 
database10 数据 库 的 事务 日 志 备份 。 


BACKUP LOG db_database10 
TO mrsoft_Backupfdw 
GO 


(5) 单 击 执行 按钮 》”， 执 行 本 实例 ， 其 运行 结果 如 图 10.40 所 示 。 


BE 习 
埋 朋 设备 已 lt 
dl EE 


Ee EE 
和 i 0 ud [96600 抹 阿 11 旭 里 妥 
10.39 创建 备份 设备 图 10.40 事务 日 志 备份 
图 秘笈 心 法 


E 


心 法 领悟 499: SQL Server 备份 事务 日 志 的 注意 事项 。 
在 SQL Server 中 备份 db_database10 数据 库 事务 日 志 的 过 程 中 ， 首 先 选 择 数据 库 的 故障 还 原 模式 ， 如 选择 
“完全 ”模式 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 如 图 10.41 所 示 。 


wa Im | sa96 lzne ws em | 


La [5 77 | 


= 
图 10.41 db_database10 数据 库 故 障 还 原 模式 
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实例 500 


趣味 指数 : 走 相 页 页 ， 


力 实例 说 明 


本 实例 首先 备份 一 个 名 为 db_database10 的 数据 库 , 然后 检查 该 数据 库 备 份 集 是 否 完整 以 及 所 有 卷 是 否 都 可 
读 。 在 查询 分 析 器 中 的 运行 结果 如 图 10.42 所 示 。 


e000 BO Re ED bute [90m 0 厂 后 4 开本 志 


图 10.42 检查 备份 集 


图 关键 技术 


本 实例 主要 应 用 RESTORE VERIFYONLY 语句 检查 数据 库 备 份 集 是 否 有 效 ， 其 语法 如 下 : 
RESTORE VERIFYONLY 
FROM < backup device>[,...n] 
[WITH 
[FILE = fle_number 
[[;] {NOUNLOAD|UNLOAD}] 
[[;]LOADHISTORY ] 
[[,] PASSWORD = { password | @password_variable } ] 
[[ 
[[ 


backup_device: 指定 还 原 时 要 使 用 的 逻辑 或 物理 备份 设备 。 
FILE = file_ number: 标识 要 还 原 或 处 理 的 备份 集 。 例 如 ，file number 为 1 表示 第 1 个 备份 集 ，file_number 
为 2 表示 第 2 个 备份 集 。 如 果 没 有 指定 file_number， 则 假定 是 指定 <backup_device> 上 的 第 1 个 备份 集 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 saa， 密码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


backup database db_database10 
to disk='E:\SQL Server Datafdw bak' 


ae verifyonly from disk=E:\SQL Server Data\fdw.bak’ 
“G3) 单 击 执行 按钮 》”， 执 行 本 实例 ， 其 运行 结果 如 图 10.42 所 示 。 
国 秘笈 心 法 
心 法 领悟 500: 检查 备份 集 的 相关 事项 。 
RESTORE VERIFYONLY 语句 用 来 验证 备份 但 不 还 原 备 份 ， 它 检查 备份 集 是 否 完整 以 及 所 有 卷 是 否 都 可 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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用 style 参数 转换 日 期 的 语句 如 下 : 


SELECT CONVERT(char(12).GETDATEQ.3) 


此 语句 把 当前 日 期 转换 为 样式 3， 即 ddimmy/yy。 


| 


实例 502 


力 实例 说 明 


本 实例 实现 对 db_database10 数据 库 tb_demo1l1 用 户 信 息 表 中 的 用 户 
名 和 密码 进行 加 密 。 注意 , 在 通过 pwdencryptO 函 数 对 相同 的 用 户 名 和 密 
码 进行 加 密 后 ， 生 成 的 结果 不 相同 并 且 是 不 可 逆 的 。 本 实例 的 运行 结果 
如 图 10.45 所 示 。 Tp ne op Porm 


宵 息 


De pe] 
本 实例 主要 应 用 加 密 函 数 pwdencrypt0 和 加 密 校 验 函 数 pwdcompare0 ec-2ni0 ls 51 hatweea0 | 00 0 行 队 8, 列 本 局 
实现 。 图 10.45 ”对 数据 库 中 的 数据 进行 加 密 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


declare @User varchar(100),@Password varchar(100) 
select @User='mrfdw'\@Password="mrgwh’ 

--Insert 插入 

insert into dbo.tb_demol1 (UP_Name.Up_Password) 
select 


@User.convert(varbinary(256),pwdencrypt(@Password)) 
--Select 查询 

Select * from tb_ demoll 

where Up_Name=@User 

and pwdcompare(@Password,Up_Password)=1 


(3) 单 击 执行 按钮 ， 执 行 本 实例 ， 其 实现 的 结果 如 图 10.45 所 示 。 
秘笈 心 法 


心 法 领悟 502: 加 密 函 数 pwdencryptO。 
由 于 此 函数 对 插入 的 相同 数据 进行 加 密 后 ， 生 成 的 结果 不 相同 而 且 不 可 逆 ， 是 一 种 非常 安全 的 加 密 手段 ， 
被 广泛 应 用 。 


.的 分 离 和 附加 商 弘 


国 实例 说 明 


为 了 方便 读者 运行 和 学 习 本 章 实例 内 容 ， 避 免 出 现 不 必要 的 操作 失误 ， 特 向 读者 介绍 一 些 操作 SQL Server 
数据 库 的 细节 内 容 。 本 实例 主要 讲解 如 何 分 离 、 附 加 数据 库 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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力 关键 技术 


本 实例 主要 应 用 xp_cmdshell 函数 和 bcp 实用 工具 实现 功能 。 

(1) xp_cmdshell 函数 

xp_cmdshell， 以 操作 系统 命令 行 解释 器 的 方式 执行 给 定 的 命令 字符 串 ， 并 以 文本 行 方式 返回 任何 输出 ， 其 
语法 如 下 : 

xp_cmdshell {command string’} [, no_output] 

参数 说 明 : 

'command string': 在 操作 系统 命令 行 解释 器 上 执行 的 命令 字符 串 。command string 的 数据 类 型 为 
varchar(255) 或 nvarchar(4000), 没有 默认 值 。command string 不 能 包含 一 对 以 上 的 双 引 号 ， 如 果 所 引用 的 文件 
路 径 或 程序 名 称 中 有 空格 ， 则 需要 使 用 一 对 引号 。 

no_output: 可 选 参数 ， 表 示 执 行 给 定 的 command_string， 但 不 向 客户 端 返回 任何 输出 。 

返回 代码 值 : 0 (成 功 ) 或 1 (失败 ) 。 

(2) bcp 实用 工具 

bcp 实用 工具 是 一 种 命令 提示 符 大 容量 复制 的 实用 工具 ， 它 以 用 户 指定 的 格式 从 操作 系统 文件 或 向 操作 系 
统 文件 复制 。 下 面 以 bcp 实用 工具 用 于 SQL Server 2000 实例 和 数据 文件 之 间 指 定 的 格式 复制 数据 为 例 ， 介 绍 
bcp 实用 工具 中 几 个 重要 的 参数 。 

加 ”Injoutlqueryoutlformat: 指定 大 容量 复制 的 方向 。In 是 指 从 文件 复制 到 数据 库 表 或 视图 ，out 是 指 从 数 
据 库 表 或 视图 复制 到 文件 。 

-c: 使 用 字符 数据 类 型 执行 大 容量 复制 操作 。 

-q: 在 bcp 实用 工具 和 SQL Server 实例 的 连接 中 执行 SET QUOTED_IDENTIFLERSON 语句 。 
-S server name[/instance name]: 指定 要 连接 的 SQL Server 实例 。 

-U login_id: 指定 用 于 连接 的 SQL Server 实例 。 

-P password: 指定 登录 ID 的 密码 。 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


EXEC master..xp_cmdshell bcp db_database10.dbo tb_demol0 out E:\tb_demol0.xls -¢ -q -S"localhost" 
-U"sa" -P" 


(3) 单 击 执行 按钮 上， 执行 本 实例 ， 其 运行 结果 如 图 10.49 所 示 。 


办 办 办 办 


数据 包 的 大 小 〔 字 节 ) : 4096 
时 捉 时 间 【 训 种) : 共 3 
TEL 


口 Rs 国 浊 s 
本 000101639 的 中 [a 5 Paster | Do cid 和 5 行 硬 8 列 1 | 


10.49 从 SQL Server 数据 库 导出 数据 至 Excel 表 中 


国 秘笈 心 法 
心 法 领悟 504: 使 用 xp_cmdshell 函数 的 注意 事项 。 
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xp_cmdshell 以 同步 方式 操作 ， 在 命令 行 解释 器 命令 执行 完毕 之 前 ， 不 会 返回 控制 。 


实例 505 


力 实例 说 明 
本 实例 讲解 将 SQL Server 中 db_database10 数据 库 的 tb_demo10 数据 表 中 的 查询 信息 生成 一 个 存储 到 本 地 EE 
得 的 tb_mrsoft.xls 文件 。 


力 关键 技术 


本 实例 同样 是 应 用 xp_cmdshell 函数 和 bcp 实用 工具 实现 ， 相 关内 容 请 读者 参考 实例 504。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 查询 分 析 器 中 选择 要 连接 的 数据 库 为 db_database10。 
(3) 在 代码 编辑 区 中 输入 SQL 语句 : 
declare @sql varchar(1000) 
set @sql ='bep 
"SELECT * FROM db_database10..tb_demo10" 
queryout  E:\SQL Server Data\tb_mrsoft.xls -c -q -S"localhost" 


ee 
EXEC master..xp_cmdshell @sql 


(4) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 运行 结果 如 图 10.50 所 示 。 
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图 10.50 ”生成 Excel 文件 


图 秘笈 心 法 


心 法 领悟 305: 将 数据 导入 到 Excel 文件 中 。 
将 数据 导入 到 Excel 中 是 程序 员 常 用 的 一 种 数据 统计 方法 ,因为 Excel 中 对 数据 的 求 和 、 排序 等 有 良好 的 支 
持 ， 而 且 将 数据 库 信息 存储 到 Excel 中 也 是 一 种 备份 数据 库 的 方法 ， 只 是 这 种 备份 方法 并 不 常用 。 


第 7 7 


PHP 操作 Access 数据 库 


连接 数据 库 

操作 Access 数据 库 
Access 数据 库 的 安全 
Access 数据 库 的 综合 运用 


YY 
至 至 至 


区 
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PHP 开发 实例 大 全 (基础 卷 ) 


11.1 连接 数据 库 


如 果 开 发 一 个 小 型 网 站 ， 利 用 Access 数据 库 不 仅 方便 操作 、 易 于 维护 ， 更 重要 的 是 可 以 节省 服务 器 资源 ， 
下 面 将 通过 具体 实例 讲解 PHP 操纵 Access 数据 库 的 方法 。 


实例 506 起 叶 指 数 : 雪 南 页 . 
图 实例 说 明 


本 实例 主要 介绍 PHP 如 何 通过 ADO 方式 连接 Access 数据 库 , 效果 如 图 11.1 所 示 , 该 页 面 显示 的 信息 是 从 
Access 数据 库 中 检索 出 来 的 ， 从 而 证 明 通 过 ADO 方式 连接 数据 库 成 功 


《0 站 项 床 开放 充 全 王 般 》 人 民 才 所 出 所 入 
CE 了 人 民 部 只 出 扳 守 


11.1 连接 Access 数据 库 


力 关键 技术 


ADO 技术 基于 通用 对 象 模 型 (COM) ,可 提供 多 种 语言 的 访问 技术 。PHP 是 通过 预先 定义 类 COM 来 使 用 
ADO 方法 操纵 Access 数据 库 的， 该 类 的 详细 说 明 如 下 : 


string com::com( string module name [, string server_name [. int codepage]]) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server name: DCOM 服务 器 的 名 字 。 

codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP MACCP, CP OEMCP, CP SYMBOL, CP THREAD ACP、 CP UTF7 和 CP UTF8。 


力 设计 过 程 
(1) 建立 数据 库 连 接 文件 conn php， 实 现 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
<2php 


$conn = new com("adodb.connection"): 
$connstr="driver={microsoft access driver (*.mdb)}: dbq=". realpath("data/db_databasel 1.mdb"); 
$conn->open($connstr); 
?> 
(2) 建立 如 图 11.1 所 示 的 页 面 ， 并 循环 显示 数据 库 中 的 所 有 图 书信 息 ， 代 码 如 下 : 
?php 
$sql="select * from tb_book"; 
S$rs=new com("adodb.recordset"); 
S$rs->open($sql.$conn,1,3): 
while(!$rs->eof) 
全 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk',"utf-8',$rs->fields(bookname)->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk',utf-8'.$rs->ficlds(pub)->value):?></div></td> 
<ltr> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 
密码 ， 单 击 “ 确 定 ” 按 钮 即 可 。 


11.2 操作 Access 数据 库 


Access 数据 库 是 小 型 项 目 后 台 支 持 的 首选 ， 在 相关 的 数据 库 操作 上 与 其 他 数据 库 有 所 不 同 。 本 节 将 通过 实 
例 详细 介绍 如 何 操作 Access 数据 库 。 


实例 508 高 级 


趣味 指数 : 但 食 食 全 


图 实例 说 明 


本 实例 主要 实现 Access 数据 库 信息 的 查询 。 运 行 本 实例 ， 在 文本 框 中 输入 某 学 生 的 学 号 ， 如 果 查 询 到 该 学 
生 的 成 绩 将 该 学 生 的 详细 成 绩 信息 显示 出 来 ， 如 图 11.4 所 示 。 


0312101 


Dalztol CD] EE EE 


图 11.4 通用 数据 信息 查询 


力 关键 技术 


通过 ADO 方式 建立 与 Access 数据 库 的 连接 已 经 在 前 面 介 绍 过 ， 但 建立 完 该 连接 后 并 不 能 对 数据 库 进行 查 
询 、 更 新 等 操作 ， 必 须 先 实例 化 COM 类 建立 记录 集 ， 然 后 通过 open0 方 法 执行 查询 语句 ， 其 关键 代码 如 下 : 


include("conn.php"); // 包 含 数据 库 连接 文件 
S$rs=new com("adodb.recordset"); // 建 立 记录 集 
S$rs->open("select * from tb_score where sno=".$_POST[sno]."".$conn.3,1); /| 执行 查询 
看 设计 过 程 
(1) 新 建 conn.php 文件 ， 建 立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
<?php 


Sconn=new com("adodb.connection"); 
Sconnstr="provider=microsoftjet.oledb.4.0:data source=".realpath("../data/db_databasel1.mdb");: 
Sconn->open($connstr); 

2> 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 学 号 提交 到 本 页 ， 在 本 页 中 根据 POST 方法 提交 的 学 号 执行 
查询 操作 ， 查 询 出 符合 条 件 的 数据 并 且 输 出 查询 结果 ， 代 码 如 下 : 


<2php 
if($_POST[submit]!=""){ 
include("conn.php"); 
Srs=new com("adodb.recordset"): 
Srs->open("select * from tb_score where sno=".$_POST[sno].™",$conn,3,1); 
if($rs->eofl| $rs->bob{ 
> 


<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 查找 到 该 学 生成 绩 ! </div> </td> 
< 
<2php 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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实例 509 


力 实例 说 明 


高 级 
趣味 指教， 机 本 页 页 ， 


如 果 记 录 集 中 的 记录 较 多 ， 用 一 个 页 面 显示 所 有 记录 会 给 用 户 的 浏览 带 来 诸多 不 便 。 为 了 解决 这 个 问题 ， 
可 以 对 数据 库 中 的 数据 进行 分 页 显示 。 运 行 本 实例 ， 如 图 11.5 所 示 。 


pn 开关 不 与。 人民 pt 入 


Delpn 逆 据 孟 开发 实 全 多 夺 a 
ASP 小 括 库 开 友 实 了 入 术 可 误工 b 居 社 
visual FoxPro 机 本 开发 信人 解 下 。 起 工业 出 睛 社 
Powar Bulder 信 基于 开发 实 列 解 泊 ”也 误工 业 比 斋 社 
visual Basicg 到 认 开 实 创 解 氏 大 起 工业 出 版 社 
| visual Baslc 本 条 畏 程 200 创 机 城 工业 流入 
刁 有 图书 47 隐 竹下 旦 示 20 种 第 3 页 失 3 责 


SQL Sm 


ET Tr 
2004 年 5 月 407 页 4 元 | 
2004 年 2 月 480 页 哲 元 | 
2004 年 12 月 321 页 36 元 | 
2003 征 9 月 458 页 各 无 | 
2003 征 9 月 400 页 43 元 | 
2003 年 6 月 460 页 向 元 | 
2003 年 1 月 358 页 39 元 | 
waiaa 站 加 


图 11.5 数据 的 分 页 显示 


图 关键 技术 


PHP 利用 COM 类 连接 数据 库 ， 可 以 直接 使 用 类 中 的 数据 成 员 完 成 很 多 操作 ， 常 用 的 数据 成 员 如 表 11.3 


所 示 。 
表 11.3 ”记录 集 对 象 常用 数据 成 员 

数据 成 员 说 明 
pagesize 设置 分 页 显示 时 ， 记 录 集 对 象 一 页 所 容纳 的 记录 数 
absolutepage 设置 当前 显示 的 为 第 几 页 ， 首 先 应 设置 pagesize 的 值 
bof 检查 当前 记录 集 对 象 所 指 位 置 是 否 为 第 一 条 记录 之 前 
eof 检查 当前 记录 集 对 象 所 指 位 置 是否 为 最 后 一 条 记录 之 后 
pagecount 显示 记录 集 当前 页 面 总 数 ， 首 先 应 设置 pageesize 的 值 
movenext 将 记录 集 对 象 的 指针 向 下 移动 一 条 


力 设计 过 程 


(1) 建立 数据 库 连接 文件 conn.php， 代 码 如 下 : 
<?php 
Sconn = new com("adodb.connection"); 
Sconnstr="driver={microsoft access driver (*.mdb)}: dbq=". 
realpath("../data/db_databasel1.mdb "); 
Sconn->open($connstr); 
> 


2) 根据 接收 到 的 查询 字符 串 的 值 确定 显示 的 信息 页 ， 代 码 如 下 : 
<php 


include("Conn/conn.php"): 

$sql="select * from tb_bookinfo order by pdate dese"; 
Srs=new com("adodb.recordset"): 
Srs->open($sql.Sconn.1.3): 

Srs->pagesize=20; 


// 包 含 数据 库 连 接 文件 conn.php 

// 查 询 也 _bookinfo 表 中 的 所 有 商品 
// 用 com 类 声明 一 个 记录 集 对 象 

// 利 用 com 类 的 open0 方 法 执行 查询 
// 设 置 每 页 最 多 显示 20 条 记录 
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(trim(intval($_GET[page]))—"")|(intval($_GET[page])>S$rs->pagecount)|(intval($_GET[page])<=0)) { 


Spage=1: 
} else{ // 否 则 使 $page 的 值 为 所 接收 的 查询 字符 串 的 数值 
Spage=intval($_GET[page]): 
和 
if($rs->eof | $rs->bof) { // 潮 断 表 中 的 内 容 是 否 为 室 ， 如 果 为 空 则 给 出 提示 
> 
<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 本 站 暂 无 商品 ! 
<Jdiv></td> 
<ltr> 
<?php 
jelse{ /不 为 空 则 分 页 显示 数据 
S$rs->absolutepage=$page; /设置 当前 显示 页 为 所 接收 的 查询 字符 串 的 值 
Smypagesize=$rs->pagesize; /定义 变量 $mypagesize 用 于 控制 当前 页 的 循环 终止 
while(!$rs->eof && $mypagesize>0) { // 记 录 集 对 象 没有 到 整个 表 尾 并 且 当 前 页 所 要 显示 的 记录 没有 完全 显示 完 ， 则 循环 显示 数据 信息 
?> 
<?php 
Smypagesize--; // 每 显示 一 条 记录 ， 应 使 $mypagesize 的 值 减 1 
S$rs->movenext; /使 记录 集 指针 移 到 下 一 条 记录 的 位 置 
} 
} 
> 


(3) 向 信息 显示 页 面 发 送 查 询 字符 串 从 而 实现 商品 信息 的 分 页 显示 ， 代 码 如 下 : 
<div align="right"> 
<?php 
if($page>=2){ 
> 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page=<?php echo Spage-1:?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 
Iphp 
} 
if($rs->pagecount<—=4){ 
for($i=1:$i<=$rs->pagecount: $i++){ 
> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i:7></a> 
Iphp 


站 
jelse{ 
forGSi=1:Si<=4:SitHf 


<a href="index.php?page=<?php echo $i:?>"><?php ccho Si:?></a> 


<a href="index.php?page=<?php 
这 $rs->pagecount>=$page+l) 
echo Spagetl1; 


一 页 "><font face="webdings"> 8 </font></a> 
<a href="index.php?page=<?php echo $rs->pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php 

} 


?> 
</div> 


国 秘笈 心 法 


心 法 领悟 509: 比较 ASP 与 PHP。 
熟悉 ASP 的 读者 可 能 会 发 现 , PHP 利用 COM 类 连接 Access 数据 库 的 思路 与 ASP 用 ADO 方法 连接 数据 库 
的 思路 类 似 ， 同 样 实现 翻 页 的 思路 也 是 类 似 的 。 
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趣味 指教 : 请 禄 庚 寅 ， 


i 


力 实例 说 明 


利用 用 户 身 份 验证 类 实现 登录 用 户 的 身份 验证 ， 不 仅 为 以 后 的 维护 工作 带 来 很 大 方便 ， 而 且 还 可 以 提高 程 
序 的 安全 性 。 运 行 本 实例 ， 如 图 11.6 所 示 ， 如 果 登 录用 户 输入 正确 的 用 户 名 和 密码 则 系统 给 出 成 功 登 录 信息 ， 
反之 系统 给 出 登录 失败 信息 。 


NT 
ez ~ 


于 下 


EE 


11.6 ”登录 Access 数据 库 成 功 


力 关键 技术 
本 实例 主要 通过 面向 对 象 的 类 来 实现 用 户 身份 的 验证 ， 用 户 身份 验证 类 的 代码 如 下 


class chk{ 
Private $name; 
private Spwd:; 
public function «construct($x,$y){ 
Sthis->name=$x; 


Srs=new com("adodb.recordset"); /创建 记录 集 对 象 
Srs->open("select * from tb_user where usemame=".$this->name." and userpwd=".$this->pwd.™",$conn,3.1); 
if($rs->eof | $rs->bof){ 
od "<script>alert(' 对 不 起 ， 密 码 或 用 户 名 错误 !):history.backO:</script>": 


a 
echo "<script>alert( 恭喜 您 登录 成 功 !):history.back0O:</script>": 
exit; 


} 
. 


} 
该 类 通过 判断 数据 库 中 查询 结果 的 游标 位 置 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 该 游标 位 于 第 
一 条 记录 之 前 或 最 后 一 条 记录 之 后 ， 则 说 明 用 户 输入 的 用 户 名 或 密码 错误 。 


力 设计 过 程 
(1) 建立 如 图 11.6 所 示 的 登录 表单 ， 代 码 如 下 


<form name="form1" method="post" action="index.php"> 
<t> 
<td height="25" colspan="2" bgcolor="#0099CC"><div align="center" class="STYLE1"> 用 户 身份 验证 </div></td> 
<t> 
<t> 
<td width="60" height="25" bgcolor="#FFFFFF"><div align="center"> 用 户 名 : </div></td> 
<td width="187" bgcolor="#FFFFFF"><div align="left">é&nbsp:<input type="text" name="usemame" size="22" 
class="inputess"></div></td> 
<ltr> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"> 密 码 : </div></td> 
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<td height="25" bgcolor="#FFFFFF"><div align="left">&nbsp:<input type="password" name="userpwd" size="22" 
class="inputess"></div></td> 
<itr> 
<t> 

‘<td height="25" colspan="2" bgcolor="#FFFFFF"><div align="center"><input name="submit" type="submit" value=" 登 录 " 
class="buttoncss"></div></td> 

</it> 
</form> 


(2) 建立 密码 验证 类 。 
(3) 美的 实例 化 并 实现 用 所 身份 的 蛤 证 代码 如 下 : 


Schkl=new chk($usemame. $userpwd): 
Schk1->chkuser(); 


心 法 领悟 10， 类 的 实例 化。 


一 般 情 况 下 ， 创 建 一 个 类 后 并 不 能 直接 对 类 中 的 属性 和 方法 进行 引用 ， 必 须 对 类 进行 实例 化 ， 即 创建 一 个 
对 象 。PHP 中 用 new 关键 字 创 建 对 象 。 


实例 511 时 
图 实例 说 明 
采用 分 栏 的 方式 将 多 张 图 片 同时 显示 在 一 个 页 面 中 , 可 以 
使 页 面 更 加 整齐 。 运 行 本 实例 ， 效 果 如 图 11.7 所 示 。 
图 关键 技术 
本 实例 实现 图 片 的 分 栏 显示 主要 依靠 标记 变量 Si， 如 果 该 
变量 的 值 能 被 5 整除 则 显示 下 一 行 ( 当 然 这 是 一 栏 显 示 5 张 图 


片 的 情况 ， 如 果 一 栏 显示 4 张 图 片 ， 可 以 通过 判断 该 值 能 否 被 4 整除 ， 依 此 类 推 ) 。 注 意 ， 显 示 一 张 图 片 后 应 
使 $i 的 数值 加 1， 实 现 该 过 程 的 代码 如 下 : 
<?phbp 
Si=1; 


while(lSrs->eob{f 
让 (Si% 5 一 0){ 


11.7 图 片 的 分 栏 显示 


> 
<td height="25"> 
<div align="left"><img sre="<?php echo iconv('gbk','utf-8'.$rs->fields(address)->value):?>" border="0">&nbsp:</div> 
<ltd> 
<ltr> 
<?php 
jelsef 


<td height="25"><div align="left"><img sre="<?php echo iconv(gbkvutf 8,Srs->fieldstaddress) >valucj:?>v border="0">&enbsp;</div> 
<htd> 


| | 设计 过 过 程 
(1) 建立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(2) 编写 “显示 信息 ”按钮 ， 单 击 此 按钮 ， 将 输出 Access 数据 库 中 存储 的 所 有 数据 ， 代 码 如 下 : 


<?php 

if$_GET[d] —"1"){ // 单 击 按钮 
S$rst = $conn -> execute("select * from th_demo") or die ("出 错 "); // 返 回 结果 集 

> 


<table bgcolor="#80E7EC" width="580px"><tr><td align="center"> 图 书 ID</td><td align="center"> 图 书 名称 </td><td align="center"> 作 者 </td><td 
align="center"> 出 版 社 </td><td align="center"> 出 版 时 间 </td></tr> 


hp 
while(!$rst -> EOF){ // 如 果 指针 没有 指向 最 后 一 条 数据 


<t> 
<td align="center" bgcolor="AFFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[0]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[1]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312", "utf-8",$rst -> ficlds[2]):?></td> 


<td align="center" bgeolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[3]):?></td> 
<td align="center" bgeolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[4]);?></td> 
</t> 
php 
S$rst -> movenext(); /指针 向 下 移动 
国 } 
(3) 编写 表单 ， 通 过 字符 串 拆 分 函数 ， 对 文本 框 内 容 进 行 拆 分 并 执行 插入 操作 ， 代 码 如 下 : 
<?php 
i PosTfmbDf /| 单 击 按钮 
这 $_POST[te] 一 "||$_POST[te] 一 "输入 字段 信息 每 一 项 用 空格 分 割 "){ 1/ 判断 文本 框 内 容 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 );location href='index.php?id=1';</script>"; //JavaSeript 提示 
Jelse{ 
S$array = explode(" ",$_POST[te]): /| 拆 分 字符 串 
if(count($array) != 5){ 1/ 判断 数组 
echo "<script>alert( 文 本 框 输入 内 容 有 误 ,数据 表 共 5 个 字段 ");location.href='index.php?id=1';</script>";  ///JavaScript 提示 
Jelse{ 
/| 转 码 操作 
,gbk', 了 
Se= =iconv(utf.g" ,gbk'Sarray[4]); 
// 判 断 是 否 插入 成 功 
if($conn -> exeeute("insert into tb_demo( id, ‘bname, author’, pub, date’)values(™.$a.™,".$b.™,".$e.™,".$d.™,".Se.")"){ 
echo "<script>alert( 插 入 数据 成 功 );location.href="'index.php?id=1";</script>"; //JavaScript 提示 
Jelse{ 
echo "<script>alert('SQL 语句 有 误 ， 请 重新 输入 ):location_ href='index.php?id=1';</script>"; 
} 
} 
| 
} 
?> 


国 秘笈 心 法 


心 法 领悟 512: Access 数据 库 的 SQL 语句 。 
Access 数据 库 与 MySQL 数据 库 的 SQL 语句 在 更 新 、 删 除 、 查 询 方面 几乎 相同 ， 但 是 在 插入 语句 方面 有 所 
不 同 。 在 编辑 插入 的 insert 语句 时 ， 数 据 表 字段 必须 由 “` ”包含 。 


实例 513 


国 实例 说 明 


Access 数据 库 虽 然 小 巧 ， 但 是 在 功能 上 并 不 逊 于 其 他 数据 库 ， 进 行 简单 的 插入 、 删 除 操作 是 很 迅速 的 。 本 
实例 通过 ADODB 连接 Access 数据 库 实现 删除 图 书信 息 的 操作 ， 运 行 结果 如 图 11.9 所 示 。 
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ADODB, 全 称 为 Active Data Objects Data Base， 是 存 取 数 据 库 所 使 用 到 的 一 组 函数 。 虽 然 PHP 是 构建 Web 
系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函 数 一 直 没有 标准 化 ， 不 同 数据 库 间 的 函数 名 称 、 参 数 差 异 很 大 ， 在 更 
换 数据 库 时 会 带 来 大 量 的 代码 修复 工作 。 这 时 就 需要 一 组 函数 库 来 隐藏 不 同 数据 库 函 数 间 的 差异 ， 以 便 开 发 者 
可 以 简单 地 切换 数据 库 ， 这 就 是 ADODB 类 库 ， 其 详细 的 讲解 请 读者 参考 本 书 第 13 章 。 


11.3 ”Access 数据 库 的 安全 


数据 库 文件 的 安全 非常 重要 ， 尤 其 是 对 于 利用 Access 数据 库 建立 的 小 型 网 站 而 言 ， 用 户 总 是 担心 数据 库 文 
件 会 不 会 被 下 载 、 用 户 名 和 密码 是 否 会 被 他 人 盗 走 、 系 统 是 否 会 被 人 攻击 等 。 下 面 通过 具体 实例 来 讲解 网 站 的 
安全 措施 。 


i 


实例 514 趣味 指数 ， 庚 良 志雄 ， 


力 实例 说 明 


为 防止 用 户 通过 下 载 Access 数据 库 文件 来 达到 窃取 机 密 信 息 的 目的 , 可 以 为 Access 数据 库 设置 密码 , 以 保 
护 数据 ， 这 样 即使 用 户 得 到 数据 库 也 会 因为 没有 密码 而 无 法 查看 数据 库 中 的 内 容 。 运 行 本 实例 ， 对 Access 数据 
库 设置 密码 的 效果 如 图 11.10 所 示 ， 在 网 站 中 连接 数据 库 的 运行 结果 如 图 11.11 所 示 。 
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图 11.10 设置 数据 库 密码 11.11 操作 带 密码 的 Access 数据 库 


力 关键 技术 


本 实例 主要 通过 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 来 设置 Access 数据 库 的 密 
码 ， 同 时 也 可 以 撤销 数据 库 密码 。 

撤销 数据 库 密码 的 过 程 为 选择 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ”命令 ， 在 弹出 的 
“撤销 数据 库 密码 ”对 话 框 中 输入 设置 时 的 密码 即 可 。 


安 提示 : 在 设置 或 者 撤销 Access 数据 库 的 密码 时 ， 必 须 将 数据 库 以 独占 的 方式 打开 。 
设计 过 程 
(1) 启动 Access 数据 库 ， 单 击 工具 栏 中 的 加 按钮 ， 弹 出“ 打开” 对话 框 ， 选 择 需 要 设置 密码 的 数据 库 文 


件 ， 例 如 bookinfo.-mdb， 单 击 “ 打 开 ” 按 钮 右 侧 的 下 三 角 按钮 加 ， 在 弹出 的 下 拉 列 表 中 选择 “以 独占 方式 打开 ” 
选项 ， 则 该 数据 库 文件 将 以 独占 方式 打开 。 


加 载 中 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 设计 过 程 
(1) 修改 实例 中 所 用 数据 库 的 扩展 名 ， 将 其 命名 为 db_news.php。 


(2) 新 建 conmn 文件 夹 ， 编 辑 conn.php 文件 ， 定 义 Access 数据 库 的 连接 方法 ， 其 代码 如 下 : 
Se =new com("adodb.connection"); 
Sconnstr—"driver={microsoft access driver (*.mdb)}: dbq=". realpath("data/db_news.php"); 


Sconn->open($connstr); 
?> 
(3) 新 建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 应 用 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 关键 
代码 如 下 : 

<php 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$sql="select * from tb_news order by pdate desc"; // 定 义 查询 语句 
Srs=new com("adodb .recordset"); // 实 例 化 类 
Srs->open($sql,$conn,1,3); // 执 行 查询 操作 
if($rs->eof | Srs->bop{ // 判 断 查询 结果 是 否 为 真 


?> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 暂 无 新 闻 信 息 ! </div></td></tr> 


Jelse{ 
while(!$rs->eof){ /循环 输出 查询 结果 
?> 
<u> 
<td height="20" align="center" bgcolor="#FFFFFF"><div align="center"> 
<?php $ficlds=$rs->ficlds(type):echo $fields->value:?> 
</div></td> 
<td height="20" align="left" bgcolor="#FFFFFF"><div align="left"> 
<?php $ficlds=$rs->ficlds(newobj);echo $fields->value:?> 
</div></td> 
<lt> 
<php 
S$rs->movenext: 


} 


?> 


图 秘笈 心 法 
心 法 领悟 515; Access 数据 库 的 安全 。 


首先 为 Access 数据 库 设置 密码 ， 然 后 更 改 Access 数据 库 文件 的 后 级 名 称 ， 通 过 这 两 项 设置 ， 相 信 Access 
数据 库 的 安全 可 以 得 到 一 定 的 保障 。 


11.4 Access 数据 库 的 综合 运用 


本 节 以 Access 数据 库 为 数据 的 存储 方式 , 开发 一 个 聊天 室 功能 模块 , 通过 这 个 功能 模块 体会 Access 数据 库 
在 完整 项 目 中 的 运用 。 


A 高 级 | 
实例 516 趣味 指数 ， 宽 本 女 页 
图 实例 说 明 


在 本 实例 中 介绍 通过 ADODB 类 库 连 接 Access 数据 库 ， 这 里 连接 的 Access 数据 库 是 具有 密码 的 ， 并 且 隐 
藏 了 Access 数据库 文件 的 后 绥 。 运 行 本 模块 中 的 top.php 文件 ， 就 可 以 测试 出 数据 库 是 否 连接 成 功 ， 如 果 连 接 
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成 功 ， 将 输出 如 图 11.14 所 示 的 页 面 。 


[3 是 an5 征 月 日 星期 = 


11.14 ”成功 连接 Access 数据 库 


图 关键 技术 


这 里 应 用 ADODB 类 库 连接 Access 数据 库 ， 并 且 Access 数据 库 设置 了 密码 ， 同 时 对 数据 库 文件 名 称 的 后 
组 进行 了 修改 。 所 以 在 封装 Access 数据 库 的 连接 类 时 ， 必 须 注意 以 下 内 容 : 


要 指定 正确 的 ADODB 类 库 的 调用 路 径 。 


Access 数据 库 的 访问 密码 为 mrsoft。 
Access 数据 库 文 件 的 后 缀 是 .php。 


图 设计 过 程 


办 办 办 罗 


由 于 使 用 ADODB 类 库 操作 Access 数据 库 ， 数 据 库 类 型 的 判断 应 该 使 用 ado_access。 
定义 连接 语句 时 ， 不 要 忘记 Driver 与 (*.mdb) 之 间 的 空格 。 


(1) 定位 ADODB 类 库 的 位 置 ， 将 其 存储 于 章 目录 11 下 ， 命 名 为 adodb5。 
(2) 定位 Access 数据 库 文件 的 位 置 ， 将 其 存储 于 11\011\data 文件 夹 下 ， 命 名 为 db_messages.php。 
(3) 在 11\011\conn 文件 夹 下 新 建 ConnDB.php 文件 ， 封 装 ADODB 连接 Access 数据 库 类 ， 其 代码 如 下 : 


<?php 

class ConnDB{ 
var $dbType; 
var $host: 
Var $userName; 
Var $pwd; 
var $dbName; 
var $isDebug; 
var $connID; 


/| 数据 库 类 型 标识 

/| 数据 库 服务 器 地 址 
/| 数据 库 服务 器 用 户 名 
// 数 据 库 用 户 密码 

// 要 连接 的 数据 库 名 
/是 否 显示 调试 信息 
/| 数据 库 连 接 ID 


function ConnDB ($dbType = ‘mysql', $host, $userName, $pwd. $dbName, SisDebug = false){ 


Sthis->dbType = $dbType: 
S$this->host = $host 
S$this->userName = $userName; 
Sthis->pwd = Spwd: 
S$this->dbName = $dbName: 
Sthis->isDebug = $isDebug: 


} 
function getConnID Of 
require_once ,adodbsladodb inc.php': 
S$this->connID = NewADOConnection($this->dbType): 


// 为 数据 库 类 型 赋 初 值 
// 为 服务 器 地 址 赋 初 值 
// 为 用 户 名 赋 初 值 

// 为 密码 赋 初 值 

/为 数据 库 名 赋 初 值 
/为 调试 信息 赋 初 值 


// 导 入 ADODB 类 库 
/生成 数据 库 连接 对 象 


让 (Sthis->dbType 一 "mysql || Sthis->dbType 一 'mssql) { /如 果 为 MySQL 数据 库 或 者 SQL Server 数据 库 


S$this->connID->Connect($this->host, $this->userName, $this->pwd. $this->dbName): 


if (Sthis->dbType — ‘mysql) { 
Sthis->connID->Execute('set names gb2312"): 
} 


} elseif (Sthis->dbType 一 'ado_aceess) { 


/通过 Connect0 方 法 建立 与 数据 库 的 连接 
// 设 置 数据 库 编码 
// 如 果 为 Access 数据 库 


// 在 连接 Access 数据 库 时 ， 编 写 连 接 语 句 一 定 要 注意 空格 的 使 用 ， 必 须 严格 执行 ， 否 则 很 可 能 导致 连接 失败 
Sthis->connID->Connect(Driver={Microsoft Access Driver (*.mdb)}:Uid=" $this->userName.'; Pwd= Sthis->pwd .'; 


Dbq= realpath($this->dbName).':"): 
j else{ 
retum false: 
7 
S$this->connID->debug = $this->isDebug: 
retum $this->connID: 


/是 否 调试 
/返回 数据 库 连接 对 象 
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function closeConnID |{ 
y @$this->connID->Disconnect|: /关闭 与 数据 库 的 连接 
} 
(4) 如 果 要 通过 封装 的 ConnDB 类 连接 数据 库 ， 必 须 对 类 进行 实例 化 ， 同 时 向 类 中 传递 参数 ， 最 终 返回 连 
接 标识 ， 该 操作 被 存储 于 config.inc.php 文件 中 。 在 该 文件 中 完成 数据 库 连 接 类 的 实例 化 ， 返 回 连接 的 标识 ， 同 
时 数据 库 操作 类 的 实例 化 也 在 该 文件 中 完成 ， 其 代码 如 下 : 


0 // 初 始 化 SESSION 变量 
require_once 'ConnDB.php'; // 包 含 数据 库 连 接 类 文件 
require_once 'AdminDB.php'; // 包 含 数据 库 操作 类 文件 
/JSconnDB = new ConnDB('access',",",",'data/db_messages.php'false); /连接 没有 密码 的 Access 数据 库 
$connDB = new ConnDB(‘ado_access',",",mrsoft','data/db_messages.php'.false); ” // 连 接 Access 数据 库 

$conn = $connDB->getConnID0: /返回 连接 标识 

S$adminDB = new AdminDB(); /实例 化 数据 库 操作 类 


(5) 新 建 聊天 室 头 文件 top.php， 通 过 include _ once 语句 包含 config.inc.php 文件 ， 返 回 数据 库 的 连接 标识 
和 数据 库 操作 类 的 实例 化 对 象 ， 在 该 文件 中 判断 当前 用 户 的 权限 ， 根 据 不 同 的 权限 输出 不 同 的 内 容 ， 其 关键 代 
码 如 下 : 


< 
ne 人 /包含 实例 化 文件 


人 

if($_SESSION["ne"]!="){ 
$arr=$adminDB->executeSQL("select * from tb_puser where usemc=".$_SESSION["nc"]."",Sconn); 
这 $arr[0][5] 1) 


| 。。 &nbsp:<a href-"setwordnullphp"> 清 空 聊 天 记录 </a>&nbsp: 
hp 


php 
if($_SESSION["ne"]!="){ 
?> 


|&nbsp;<a href-"logout.php"> 退 出 聊天 室 </a>&nbsp:| 
<?php 
} 


?> 


国 秘笈 心 法 


心 法 领悟 516: 通过 ADODB 类 库 操作 具有 密码 的 Access 数据 库 。 
在 通过 ADODB 类 库 操作 Access 数据 库 时 ， 如 果 Access 数据 库 没 有 设置 密码 ， 那 么 设置 Access 数据 库 的 
类 型 为 access; 如 果 Access 数据 库 设 置 了 密码 ， 那 么 Access 数据 库 的 类 型 必须 设置 为 ado_access。 


实例 517 趣味 指数 : 傅 塘 请 良 | 
实例 说 明 


在 本 实例 中 讲解 ADODB 操作 Access 数据 库 方法 的 封装 。 在 聊天 室 的 用 户 登录 模块 中 ， 应 用 数据 库 操作 
AdminDB 中 的 executeSQL() 方 法 完成 登录 用 户 的 验证 和 登录 信息 的 添加 操作 ， 其 运行 效果 如 图 11.15 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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(2) 在 js/checkjs 文件 的 open_chknc0 方 法 中 调用 chkusernc.php 文件 ， 验 证 提交 的 用 户 名 是 否 被 占用 ， 其 
关键 代码 如 下 : 


<?php 
Snc=trim($_GET[ne]): 
ifSnc—"){ 
echo "请 输入 用 户 上 昵称 !"; 
}else{ 
Sinfo=$adminDB->executeSQL("select * from tb_puser where useme=". $nc."",Sconn); 
这 !$info){ 
echo " 菇 喜 您 ,该 昵称 未 被 占用 !"; 
jelse{ 
echo "对 不 起 ,该 昵称 已 被 占用 !"; 
} 


3) 新 建 saveuser.php 文件 ， 验 证 登录 用 户 名 是 否 被 占用 ， 如 果 用 户 名 可 用 ， 将 用 户 登录 信息 存储 到 指定 
数据 表 中 ， 并 且 跳 转 到 聊天 室 主页 面 ， 否 则 提示 用 户 名 不 可 用 ， 或 者 用 户 登录 失败 ， 其 关键 代码 如 下 : 
<Iphp 


include_once("conn/config.ine.php"); // 包 含 数据 库 连接 、 操 作 类 的 实例 化 文件 
$usemc=trim($_POST[usemc]): /获取 提交 的 用 户 名 
$sql=$adminDB->executeSQL("select * from tb_puser where usernc=".$userne."",$conn); // 验 证 用 户 名 是 否 被 占用 
这 $sqD){ 

人 '<script language=javascript>alert(' 对 不 起 ， 该 昵称 已 被 其 他 用 户 使 用 !"):history.back0;</script>"; 


yoke{ 
Slogintime=date("Y-m-j H:i:s"); // 定 义 时 间 
Suserhead=$_POST[userhead]; 
Sonline=1; 
Sip=getenv("REMOTE_ADDR"); /获取 下 
S$email=trim($_POST[email]); /获取 用 户 提交 的 E-mail 
Smark=0; 
Snowtime=time(); /定义 时 间 恰 
S$arr=$adminDB->executeSQL("insert into tb_puser(useme,logintime,ip,email.mark.userhead,online,nowtime) values (‘$userme','$logintime','$ip', 
‘$email','Smark','$userhead','$online','S$nowtime’)",$conn); // 执 行 用 户 信息 的 添加 操作 
这 Sarn{f 
$_SESSION["ne"]=$useme; /用 户 登录 成 功 后 将 用 户 名 赋 给 SESSION 变量 
echo "<script>window.location href='chat.php':</script>"; // 跳 转 到 聊天 室 主页 
yelse{ 
echo "添加 失败 ! "; 
} 
> 
力 秘笈 心 法 


心 法 领悟 517: 使 用 getenv0 函 数 获取 客户 端的 了 人 P 地 址 。 
在 本 实例 中 ， 应 用 getenv0 函 数 获取 客户 端的 IP 地 址 ， 其 作用 与 $_ SERVER[REMOTE ADDR'] 是 相同 的 。 


高 级 | 
实例 518 趣味 指数 : 要， 
图 实例 说 明 


聊天 室 的 主页 面 由 头 文件 top.php、 尾 文件 bottom.php、 发 布 聊天 信息 chatphp、 聊 天 内 容 listchat.php 和 聊 
天 参与 者 listuserphp 共 5 个 部 分 组 成 ， 其 运行 效果 如 图 11.16 所 示 。 
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}else{ 
echo $_SESSION ["sne"]: 
} 
} 
} 
>> 
<input type="hidden" name="touserl"value=" 
<?php 


Suseme =trim ($ SESSION ["ne"] ); 
Sinfo = $adminDB->executeSQL ( "select * from tb_puser where useme=" . Suseme . ™", $conn ): 
if($info [0] [5]—= D { 

if($_SESSION ["sne"]—"") { 


echo "所 有 人 "; 
}else { 
echo $_SESSION ["sne"]: 
} 
} else { 
让 (Sinfoc [total] = 0) { 
echo "请 选择 发 送 人 "; 
}else { 
if($_SESSION ["snc"] =—"") { 
echo "请 选择 发 送 人 "; 
}else{ 
echo $_SESSION ["sne"]: 
} 
. 


} 

?>"> &nbsp:&nbsp: 
<input type="submit" name="submit" value= "发送 " class="buttoncss" />&nbspi&nbsp: 
<input name="reset" type="reset" class="buttoncss" value=" 重 写 "> 


</form> 
(2) 新 建 saveword.php 文件 ， 将 聊天 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 
<?php 
ee ("conn/config.inc.php"); // 包 含 配置 文件 
S$fromuser = trim ( $_SESSION ["ne"] ); /获取 登录 用 户 名 称 
$sql = $adminDB->executeSQL ( "select * from tb_puser where usernc=" . $fromuser . "", Sconn ); /判断 用 户 是 否 存在 
if(! $sq)) { 
echo "<script>alert(' 对 不 起 ,等 待 时 间 过 长 ， 请 重新 登录 !");window.location href='logout.php';</script>"; 
exit 0: 
} 
Stouser = $_POST ['touserl']: 
让 (Stouser 二 "所 有 人 ") { 
Stouser = "all"; 


} 
Scontent =$_POST [bbs_content]; 
Spubtime = date ( "Y-m-i H:i:s" ); 
Snowtime = time (; 
Sarr = $adminDB->executeSQL ( "insert into tb_message(touser,fromuser,content.pubtime.nowtime) values ('$touser','$fromuser’, '$content', '$pubtime’, 
‘$nowtime’)", $conn ); 1/ 执行 信息 的 添加 操作 
证 (SarD { 
echo "<seript>window .location href='chat.php':</script>"; 
}else{ 
echo "添加 失败 1 ":; 
} 


了 


(3) 新 建 listuser.php 文件 ， 输 出 聊天 室 当 前 的 在 线 用 户 ， 并 通过 JavaScript 脚本 中 的 selectuser() 方 法 调用 
selectuser.php 文件 ， 完 成 聊天 对 象 的 选择 ， 其 关键 代码 如 下 : 


<script language="javascript"> 
function selectuser(x){ 
parent.form_bbs.touser.value=x; 
parent form_bbs.touserl.value=x; 
window.location href='selectuser.php?usernc="+x: 
} 
</script> 
<table width="120" border="0" align="center" cellpadding="0" cellspacing="0"> 
<?php 
Sarray = $adminDB->executeSQL ( "select * from tb_puser where online=1 ", Sconn ): 


702 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 


} 
} 


ey 
</table> 
(6) 新 建 function.php 文件 ,编辑 自 定义 函数 unhtml0 对 聊天 室 中 输出 的 聊天 信息 进行 格式 化 ;编辑 getday0 

函数 计算 时 间 。 

心 法 领悟 518: 私 聊 功能 的 实现 。 

PHP 中 实现 私 聊 的 方法 有 多 种 ， 用 SESSION 实现 私 聊 相 对 简单 ， 本 聊天 室 中 私 聊 的 关键 代码 如 下 : 

人 |$_SESSION["nc"]—$info[fromuser] ){ 

/显示 私 聊 内 容 


<?php 


> 

上 述 简 短 的 代码 说 明了 实现 私 聊 的 原理 ，$_SESSION["ne"] 保 存 的 是 当前 登录 用 户 的 昵称 ，$info[touser] 表 
示 当 前 聊天 内 容 要 发 送 的 对 象 。 如 果 两 者 相等 ， 则 显示 出 该 聊天 内 容 ; 否则 不 显示 ， 或 者 在 
$_SESSION["nc"] 一 $info[ffomuser] 的 情况 下 也 显示 聊天 内 容 ， 这 种 情况 表示 发 送 用 户 可 以 看 到 自己 所 发 送 的 聊 
天 内 容 。 


力 实例 说 明 


在 聊天 室 模块 中 有 一 个 特殊 用 户 tsoft， 即 聊天 室 的 管理 者 ， 可 以 行使 聊天 室 的 管理 权限 ， 发 布 公告 消息 、 
清空 聊天 记录 。 管 理 员 登录 的 运行 效果 如 图 11.17 所 示 。 


11.17 聊天 室 管理 员 登 录 


力 关键 技术 


在 聊天 室 管理 员 登 录 页 面 中 , 关键 是 通过 AdminDB 类 中 的 executeSQL( 方 法 判断 输入 的 用 户 名 和 密码 是 否 
正确 ， 如 果 正 确 则 说 明 是 管理 员 ， 将 该 用 户 名 存储 到 SESSION 变量 中 。 只 有 当前 用 户 具 备 了 管理 员 的 权限 才 可 
以 执行 清空 聊天 记录 的 操作 。 

图 设计 过 程 
(1) 新 建 admin_login.php 文件 ， 创 建 form 表单 将 用 户 名 和 密码 提交 到 admin_login_ok.php 文件 中 ， 完 成 
管理 员 登 录 操 作 。 
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12.1 连接 Oracle 数据 库 


本 节 将 介绍 在 PHP 中 如 何 实现 与 Oracle 数据 库 的 连接 ， 这 里 分 别 讲解 通过 Oracle 函数 库 和 ADODB 连接 
及 操作 Oracle 数据 库 。 


连接 Oracle 数据 库 高 级 


1 
| 
趣味 指数 : 寅 全食 从 | 


力 实例 说 明 


PHP 连接 Oracle 数据 库 的 方法 很 多 ， 这 里 介绍 通过 PHP 中 自 带 的 Oracle 函数 库 来 完成 对 Oracle 数据 库 的 
操作 。 在 本 实例 中 ,应 用 oci connectO 函 数 连接 Oracle 数据 库 ， 然 后 应 用 oci_parse0 函 数 执行 查询 语句 ， 最 终 通 
过 oci_fetch_array0 函 数 和 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 运行 结果 如 图 12.1 所 示 。 


2 二 站 


EL le 


图 12.1 oci_connect0 函 数 连接 Oracle 数据 库 


力 关键 技术 


在 PHP 的 Oracle 函数 库 中 提供 有 完成 对 Oracle 数据 库 操作 的 函数 ,这 里 只 对 本 实例 中 应 用 的 函数 进行 详细 
介绍 。 


(1) oci_connect0 函 数 建 立 一 个 到 Oracle 服务 器 的 连接 ， 返 回 一 个 连接 标识 符 ， 其 语法 如 下 : 


Tesource oci_connect( string username, string password [, string db [. string charset [. int session_mode]]] ) 


oci_connect0 函 数 的 参数 说 明 如 表 12.1 所 示 。 


表 12.1 oci_connect() 函 数 的 参数 说 明 
参数 说 明 
Username 必 选 参数 ， 指 定数 据 库 中 的 用 户 名 
_password 必 选 参数 ， 指 定数 据 库 中 用 户 的 密码 
可 选 参数 ， 包 含 要 连接 的 本 地 Oracle 的 实例 或 者 在 msnames.ora 中 条 目的 名 字 。 如 果 没有 指定 该 参数 ，PHP 
使 用 环境 变量 ORACLE _SID 〈Oracle 实例 ) 或 TWO_TASK (tnsnames.ora) 来 确定 连接 哪 一 个 数据 库 
使 用 Oracle 服务 器 9.2 或 更 高 版 本 时 ， 可 以 指定 charset 参数 ， 被 用 于 新 的 连接 。 如 果 使 用 低 于 9.2 版 本 的 
Oracle 服务 器 ， 本 参数 将 被 忽略 并 以 NLS_LANG 环境 变量 蔡 代 
该 参数 自 版 本 1.1 起 可 用 并 接受 如 下 值 : OCIL DEFAULT、OCI SYSOPER 和 OCI SYSDBA。 如 果 指 定 
session mode |OCI SYSOPER 或 OCI SYSDBA 其 中 之 一 ，oci_ connectO 函 数 将 尝试 使 用 外 部 认证 信息 建立 特权 连接 。 特 
权 连 接 默认 被 禁止 ， 如 果 要 启用 ， 需 要 将 oci8.privileged_connect 设置 为 On 


db 


charset 
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[人 说 明 : 对 oci_connectO 函 数 用 同样 的 参数 第 二 次 及 之 后 的 调用 将 返回 第 一 次 调用 所 返回 的 连接 句柄 。 即 对 
一 个 句柄 发 出 的 查询 也 适用 于 另 一 个 句 枉 ， 因 为 它们 是 同一 个 句 枉 。 如 果 需 要 两 个 句柄 在 事务 上 互 
相隔 离 ， 则 使 用 oci new_connectO 函 数 蔡 代 。 

(2) oci_parse() 函 数 配置 Oracle 语句 预备 执行 ， 其 语法 如 下 : 
Tesource oci_parse( resource connection, string query ) 
参数 说 明 : 
connection: 必 选 参数 ， 数 据 库 连接 成 功 后 返回 的 连接 标识 符 。 
query: 必 选 参数 ， 执 行 的 SQL 语句 。 
oci parse0) 函 数 是 最 常用 的 函数 ， 在 操作 Oracle 数据 库 时 ， 无 论 是 执行 查询 、 修 改 、 删 除 或 更 新 操作 ， 该 函 

数 是 必须 使 用 的 ,只 有 通过 该 函数 在 connection 上 配置 query 并 返回 语句 标识 符 后 , 才 可 以 用 于 其 他 函数 的 操作 ， 

例如 oci_bind_by_name0 〇 函数 、oci_execute() 函 数 。oci_parse0 函 数 在 出 错时 返回 FALSE。 


_Bg 技巧 : oci_parse 函 数 并 不 验证 参数 query。 验 证 参数 query 是 否 为 合法 的 SQL 或 者 PL/SQL 语句 的 唯一 方 
法 是 执行 语句 。 


(3) oci_execute(0 函 数 执行 一 条 之 前 被 解析 过 的 语句 (参见 oci_parse0 函 数 ) 。 如 果 成 功 则 返回 TRUE; 否 
则 返回 FALSE， 其 语法 如 下 : 


bool oci_execute ( resource stmt [, int mode] ) 

参数 说 明 : 

stmt: 必 选 参数 ， 获 取 的 语句 标识 符 。 

mode: 可 选 参数 ，mode 允许 定义 执行 模式 (默认 是 OCL COMMIT ON _SUCCESS) 。 如 果 不 需 要 将 语句 
自动 提交 ， 则 把 mode 设 为 OCL DEFAULT。 


< 注意 : 在 使 用 OCI DEFAULT 模式 时 将 建立 一 个 事务 ,事务 会 在 关闭 连接 或 者 脚本 结束 时 自动 回 滚 。 需 要 
明确 调用 oci_commitO 函 数 来 提交 事务 ， 或 者 调用 oci rollback0 函 数 中 止 事务 。 


(4) oci_fetch_array0 函 数 ， 从 结果 集中 获取 一 行 作为 关联 数组 或 数字 数组 或 者 二 者 兼 有 。 如 果 没 有 更 多 行 
则 返回 FALSE， 其 语法 如 下 : 


array oci_fetch_array( resource statement [. int mode] ) 
oci_fetch_arrayO 函 数 中 可 选 的 第 2 个 参数 mode 是 一 个 常量 ， 该 参数 的 默认 值 是 OCL BOTH， 其 可 选 值 如 
表 12.2 所 示 。 


表 12.2 oci_fetch_array() 函 数 的 参数 mode 的 可 选 值 


参数 说 了 明 
OCI BOTH 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 
OCI ASSOC 得 到 关联 索引 (如 同 oci_fetch_ assocO) 
OCI NUM 得 到 数字 索引 (如 同 oci_fetch rowO) 


创建 一 个 空 元 素 为 NULL 字段 
返回 LOB 的 值 的 描述 


OCI RETURN NULLS 
OCI RETURN LOBS 


oci_fetch_array0 函 数 是 oci_fetch_row0 函 数 的 扩展 版 本 。 除 将 数据 以 数字 索引 方式 存储 在 数组 中 之 外 , 还 可 
以 将 数据 作为 关联 索引 存储 ， 用 字段 名 作为 键 名 。 

如 果 结 果 中 有 两 个 或 以 上 的 列 具 有 相同 的 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 必 须 用 该 列 的 
数字 索引 或 给 该 列 起 个 别名 。 对 于 有 别名 的 列 ， 不 能 再 用 原来 的 列 名 访问 其 内 容 。 
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图 12.2 ADODB 操作 Oracle 数据 库 


上 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 adodb 类 库 文件 ， 需 要 读者 自行 下 载 
并 复制 到 本 章 的 12 文件 夹 下 ， 并 且 命 名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


力 关键 技术 


使 用 ADODB 连接 数据 库 系 统 应 用 ADONewConnection0 〇 函数 ; 如果 选择 持久 化 连接 数据 库 则 使 用 PConnectO 
函数 ， 如 果 选 择 非 持 久 化 连接 则 使 用 ConnectO 函 数 。 
(1) ADONewConnection0 函 数 用 于 连接 数据 库 系统 ， 其 语法 如 下 : 


ADONewConnection($databaseType) 
参数 $databaseType 表示 要 连接 的 数据 库 系 统 的 名 称 ， 如 mysql、oci8 等 。 


(2) PConnect0 函 数 实现 与 数据 库 持久 化 连接 ， 其 语法 如 下 : 
PConnect(Shost[$user],[Spassword],[Sdatabase]) 


参数 说 明 : 

$host; 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 


(3) Connect0 函 数 ， 实 现 与 数据 库 非 持 久 化 连接 ， 其 语法 如 下 : 
Connect(Shost,[$user].[$password].[$database]) 


参数 说 明 : 

$host: 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
Suser: 数据 库 用 户 名 。 

$password: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 


-GBS 技巧 : 持久 化 连接 和 非 持 久 化 连接 的 区 别 : 持久 化 连接 不 用 每 次 都 创建 新 连接 ， 可 以 增加 程序 的 执行 速度 ， 
但 是 有 些 数据 库 不 支持 此 函数 ， 那 么 就 需要 使 用 ConnectO 函 数 来 替代 PConnectO 函 数 。 


(4) 应 用 execute0 函 数 执行 SQL 语句 ， 应 用 EOF 变量 、while 语句 和 MoveNext0 函 数 完成 数据 的 循环 输 
出 。 有 关 ADODB 类 库 中 函数 的 详细 讲解 请 参考 第 13 章 。 


设计 过 程 
(1) 将 下 载 的 ADODB 类 库 命名 为 adodb5， 存 储 于 12 文件 夹 下 ， 并 且 在 12 文件 夹 下 创建 文件 夹 521 作 
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A 高 级 | 
实例 522 趣味 指数 : 砍 页 友 妆 
图 实例 说 明 


在 本 实例 中 ， 仍 然 应 用 ADODB 操作 Oracle 数据 库 ， 在 完成 数据 库 中 的 数据 循环 输出 的 同时 ， 增 加 一 个 数 
据 库 中 数据 的 删除 操作 ， 通 过 超 链 接 删除 员工 信息 ， 其 运行 结果 如 图 12.3 所 示 。 
各 9 生理 纹 、 


八 11 MIINF 首页 | 员工 录入 | 考勤 各 理 
明日 图 蔬 “明日 软件 。“ 奖 低 条 例 


和 Wri : [2008-08-10 


ED 
图 12.3 ”删除 Oracle 数据 库 中 的 数据 


图 关键 技术 


本 实例 同样 应 用 ADODB 类 库 完成 对 Oracle 数据 库 的 连接 和 操作 ， 具 体 连接 方法 可 以 参考 实例 521， 这 里 
不 再 装 述 。 

(1) execute0 函 数 执行 SQL 语句 ， 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 失 败 则 返回 FALSE， 其 语 
法 如 下 : 
execute($sql[,$inputarr=false]) 

参数 $sql 指定 要 执行 的 SQL 语句 ， 参 数 $inputarr 设置 传 入 的 结合 变量 ， 如 果 没 有 设置 $inputarr， 则 $sql 为 
普通 的 SQL 语句 ， 那 么 execute0 函 数 的 格式 如 下 : 


S$connect->execute('select * from tb_user where id=1") 


如 果 设 置 了 $inputarr， 那 么 execute0 〇 函数 的 格式 如 下 : 


Sconnect -> execute('select * from tb_user where id = ?armray(SvD) 


(2) 要 对 结果 集 进行 操作 ， 首 先 要 确定 结果 集中 指针 的 位 置 ， 控 制 结果 集中 指针 的 方法 如 表 12.3 所 示 。 
表 12.3 ADODB 类 库 控制 结果 集中 指针 的 方法 


方 ” 法 说 明 
fields 变量 。 | 保存 当前 指针 所 指向 的 记录 
EOF 变量 。 | 记录 当前 指针 是 否 指向 最 后 一 条 记录 。 如 果 是 ， 则 返回 TRUE， 否 则 返回 FALSE 
MoveNext0 ”| 将 ADORecordSet (结果 集 ) 的 指针 下 移 一 位 。 成 功 则 返回 TRUE， 否 则 返回 FALSE 
将 ADORecordSet (结果 集 ) 的 指针 移动 到 指定 位 置 。 如 果 S$to 等 于 0， 则 指针 指向 结果 集 的 第 一 条 数据 ; 
如 果 $to 的 值 大 于 结果 集 ， 则 指针 指向 最 后 一 条 数据 。 注 意 ， 这 里 的 变量 $to 只 能 是 绝对 定位 
MoveFirstO ”| 将 指针 移动 到 第 一 条 数据 ， 等 同 于 Move(0) 


MoveLastO 将 指针 移动 到 最 后 一 条 数据 ， 等 同 于 Move(RecordCount0-1) 


Move($to) 
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力 设计 过 程 
这 里 在 实例 521 的 基础 上 增加 删除 数据 库 中 数据 的 功能 ， 其 具体 的 方法 如 下 : 


(1) 在 index.php 文件 中 为 输出 的 每 条 数据 添加 一 个 删除 超 链接 ， 链 接 到 delete_ok.php 文件 ， 将 数据 的 ID 
作为 参数 传递 到 delete_ok.php 文件 中 ， 其 关键 代码 如 下 : 
<a href="delete_ok.php?conn_id=<?php echo $rst->fields [0]; ?>"> 删 除 </a> 
(2) 创建 delete_ok.php 文件 ， 以 超 链接 传递 的 参数 值 为 条 件 ， 执 行 删 除 操作 ， 删 除数 据 表 指 定 的 记录 ， 其 
代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"): // 包 含 数据 库 连 接 文件 
$sql="delete from tb_user where id=".$_GET['conn_id].™"; // 定 义 删除 语句 

Srst = $conn->execute ( $sql ) or die ( ‘error: '. Sconn->errorMsg 0 ): 。“// 执 行 删除 语句 

这 Srsb{ 


echo "<script>alert( 信息 删除 成 功 ! ):windowJocation href='index.php':</script>"; 
jelsef 

echo "<script>alert( 信息 删除 失败 ! ):windwo.location href='index.php'</script>"; 
?> 


国 秘笈 心 ; 
心 法 领悟 522: ADODB 类 库 。 


在 本 章 中 只 是 应 用 ADODB 类 库 连 接 及 操作 Oracle 数据 库 ， 其 实 ADODB 连接 和 操作 任何 数据 库 的 函数 、 
方法 都 是 相同 的 ， 有 关 ADODB 类 库 的 具体 运用 将 在 第 13 章 中 进行 详细 的 讲解 。 


12.2 操作 Oracle 数据 库 


PHP 对 Oracle 数据 库 有 很 好 的 函数 支持 ， 用 户 可 以 通过 这 些 函 数 像 操作 MySQL 数据 库 一 样 操作 Oracle 数 
据 库 。 


oy 


实例 523 : 趣味 指数 : 座 庚 次 安 


力 实例 说 明 


本 实例 应 用 PHP 和 Oracle 数据 库 创建 一 个 企业 用 户 管理 模块 ， 实 现 用 户 信息 的 添加 、 查 询 和 更 新 操作 。 运 
行 结果 如 图 12.4 所 示 。 


fID 损 二 用 P、 [2 司 到 


D RPS 到 名 和 氛 作 


12.4 企业 用 户 管理 操作 页 面 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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四 设计 过 程 

本 实例 所 讲解 的 技术 已 经 在 实例 523 中 应 用 ， 在 本 实例 中 完全 应 用 上 一 实例 的 内 容 ， 有 关 其 创建 过 程 这 里 
不 再 次 述 。 

定义 到 index.php 文件 ， 在 员工 信息 查询 的 forml 表单 中 ， 员 工 ID 下 拉 列 表 框 值 就 是 通过 oci_fetch_ array0 
函数 和 while 语句 动态 添加 的 ， 其 关键 代码 如 下 : 


<form id="form]" name="foml" method="post" action="index.php"> 
<tr> 
<td height="30" align="right" class="STYLE3"> 按 照 ID 搜索 用 户 :</td> 
<td height="30" align="left" class="STYLE3"> 
<sclect name="select"> 
< 
include("conn/conn.php"); 
Squery="select * from tb_user "; 
Sresult=oci parse($conn,$query); 
Sr = oci_execute($result, OCI DEFAULT); 
while($row=oci_fetch_array(SresultOCIL RETURN_NULLS){ 
> 


<option value="<?php echo $row[0]:?>"><?php echo Srow[0]:?></option> 
<?php 
oci_close(Sconn); 
> 


</select></td> 
<ir> 
</form> 


有 关 本 实例 的 其 他 内 容 在 实例 523 中 已 经 介绍 ， 这 里 不 再 歼 述 。 
心 法 领悟 524: 使 用 oci_fetch_array() 函 数 的 注意 事项 。 


(1) 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 
(2) 使 用 oci_fetch_array0 函 数 并 不 比 使 用 oci_fetch_row0 函 数 慢 ， 而 且 还 能 提供 更 多 的 返回 值 。 


CR ， 
高 级 | 
实例 525 趣味 指数 : | 

用 实例 说 明 


号; 明日 人 管理 系统 


本 Es 


图 12.6 统计 数据 库 中 数据 的 记录 总 数 


力 关键 技术 
本 实例 中 ， 统 计数 据 库 中 数据 的 记录 总 数 应 用 的 是 oci_fetch_all0 函 数 ， 然 后 在 foreach 和 for 语句 的 辅助 之 
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下 完成 数据 库 中 数据 的 循环 输出 。 
oci_fetch allO 函 数 将 获取 的 所 有 数据 存储 到 一 个 数组 中 。 它 从 一 个 结果 中 获取 所 有 的 行 到 一 个 用 户 定 义 的 
数组 ， 返 回 获取 的 行 数 ， 如 出 错 则 返回 FALSE， 其 语法 如 下 : 


int oci_fetch all ( resource statement array &output [, int skip [, int maxrows [, int flags]]] ) 


oci fetch all0 函 数 的 参数 说 明 如 表 12.6 所 示 。 
表 12.6 oci_fetch_all() 函 数 的 参数 说 明 


参数 说 明 

statement 必 选 参数 ， 获 取 的 语句 标识 符 

output 必 选 参数 ， 定 义 存储 数据 的 数组 

skip 可 选 参数 ， 从 结果 中 获取 数据 时 ， 最 开始 忽略 的 行 数 〈 默 认 值 是 0， 即 从 第 一 行 开 始 ) 
maxrows 可 选 参数 ， 要 读 取 的 行 数 ， 从 第 skip 行 开始 (默认 值 是 -1， 即 所 有 行 ) 


可 选 参数 ，flags 参数 可 以 是 下 列 值 的 任意 组 合 : 
OCI FETCHSTATEMENT BY ROW 


flags OCI FETCHSTATEMENT_BY_COLUMN (上 默认 值 ) 
OCL NUM 
OCT ASSOC 
力 设计 过 程 
(1) 新 建 conn 文件 夹 ,编写 conn.php 文件 连接 Oracle 数据 库 , 并 设置 数据 库 的 编码 格式 为 UTF-8。conn.php 
的 代码 如 下 : 
<?php 


/连接 数据 库 名 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
/如 果 Oracle 数据 库 服 务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
S$conn=oci connect("system", "mrsoft","oracle", "utf8") or dir(oci_errorO); 
2 
(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 执 行 查询 语句 ， 通 过 oci_fetch_all0 函 数 获取 数据 库 中 总 
的 记录 数 ， 并 且 将 查询 结果 存储 到 $results 数组 中 ， 最 后 通过 foreach 语句 和 for 语句 循环 输出 数组 中 的 数据 ， 其 


关键 代码 如 下 : 
<?php 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 
$stmt = oci_parse($conn, "select * from tb_user"); // 预 置 Oracle 查询 语句 
oci_execute($stmt); // 执 行 查询 语句 
Snrows = oci_fetch_all($stmt, $results): // 获 取 查询 结果 的 记录 数 
ff($nrows > 0) { // 判 断 查询 结果 
> 
<t> 
<?php 
foreach ($results as $key => $val) { /循环 输 出 数据 库 中 字段 的 标题 
> 
<td height="30" align="center" valign="middle" bgcolor="#FFFFFF"><?php echo $key:?></td> 
<2php 
沁 
</tr> 
<?php 
for ($i= 0: $i < $nrows: $it+) { // 根 据 记 录 总 数 执行 for 循环 
> 
<t> 
<?php 
foreach ($results as $data) { // 输 出 数据 库 中 的 数据 
> 
<td align="center" valign="middle" bgcolor="#FFFFFF"><?php echo $data[$i]:?></td> 
<?php sy 
> 


717 


PHP 开发 实例 大 全 (基础 卷 ) 


<td height="35" colspan="5" align="right" bgcolor="#FFFFFF"><span class="STYLE1"><?php echo "总 共有 $nrows 记录 !":?> </td> 
</tr> 


<Iphp 

Jelse{ 

?> 

<tr><td colspan="5" align="center" bgcolor-"#FFFFFF"> 无 数据 <ltd> 
<ltr> 

ee 

oci_close(Sconn); 

?> 


心 法 领悟 525: oci_fetch_all0 函 数 的 应 用 总 结 。 
应 用 oci_fetch_all0 函 数 获取 数据 库 中 总 的 记录 时 ， 在 其 返回 的 数组 中 不 但 包括 数据 表 中 的 数据 而 且 还 包括 
数据 表 字 段 的 名 称 。 因 此 ， 在 应 用 oci_fetch_all0 函 数 循环 输出 数据 表 中 的 数据 时 ， 不 必 单 独 定义 数据 表 字段 的 


实例 526 趣味 指数 : 福 食 三 从 


有 


力 实例 说 明 


如 果 采 用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 ， 那 么 一 旦 数据 表 中 的 字段 发 生变 化 ， 再 通过 原来 的 表 
格 输出 数据 表 中 的 数据 时 ， 其 运行 效果 将 如 图 12.7 所 示 ， 页 面 输出 内 容 是 不 完整 的 。 


导致 页 面 不 完整 


pyr 


12.7 采用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 


如 果 采 用 动态 读 取 数 据 表 中 的 字段 和 数据 的 方法 就 可 以 避免 图 12.7 所 示 的 问题 ,无 论 字段 发 生 怎样 的 变化 ， 
在 页 面 中 输出 的 数据 都 是 完整 的 ， 不 必 对 页 面 的 设计 进行 重新 调整 ， 其 运行 效果 如 图 12.8 所 示 。 


人 aial 
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图 关键 技术 


在 本 实例 中 ， 首 先 应 用 oci_ num _ fieldsO 函 数 获取 数据 表 中 数据 的 列 数 ， 其 语法 如 下 : 


int oci_num fields( resource statement ) 
该 函数 返回 参数 statement 中 列 的 数目 ， 其 中 参数 statement 为 oci_parse0 函 数 返回 的 标识 符 。 
然后 应 用 oci_field_name0 函 数 动态 获取 数据 表 中 的 字段 信息 ， 其 语法 如 下 : 


string oci_field_name( resource statement. int field ) 


该 函数 返回 与 字段 数字 索引 〈 从 1 开始 ) 相对 应 的 字段 名 。 
最 后 应 用 oci_fetch rowO 函 数 完成 数据 库 中 数据 的 循环 输出 ， 以 数字 作为 数组 的 索引 ， 其 语法 如 下 ; 


array oci_fetch row( resource statement ) 


该 函数 从 和 指定 的 结果 标识 关联 的 结果 集中 获取 一 行 数据 并 作为 数组 返回 , 如 果 没 有 更 多 行 则 返回 FALSE。 


每 个 结果 的 列 存储 在 一 个 数组 的 单元 中 ， 数 字 索 引 从 0 开始 。 


通过 本 实例 中 介绍 的 函数 循环 输出 数据 库 中 的 数据 ， 可 以 避免 因数 据 表 增加 字段 或 者 减少 字段 而 要 重新 设 


计 页 面 的 麻烦 。 
力 设计 过 程 


(1) 新 建 comn 文件 夹 , 编写 conn.php 文件 ,定义 Oracle 数据 库 的 连接 方法 , 设置 数据 库 的 编码 格式 为 UTF-8。 
(2) 新 建 index.php 文件 ， 首 先 包含 数据 库 连 接 文件 ， 然 后 应 用 oci_num_fields0 和 oci_field_name0 函 数 以 
及 for 语句 完成 数据 表 中 字段 名 称 的 输出 。 最 后 应 用 oci_fetch_row0 函 数 和 while 语句 ， 根 据 数据 表 中 字段 的 列 


数 完成 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

include("conn/conn.php"): // 包 含 数据 库 连接 文件 
$stmt = oci_parse($conn, "select * from tb_user”); // 定 义 查询 语句 
Oci_execute($stmt); // 预 置 Oracle 语句 
Sncols = oci_num _fields($stmt); /获取 数据 表 字 段 的 列 数 
for ($i= 1: Si<= $ncols: $it+){ /| 执行 for 循环 
S$ficld_name =oci_ficld name($stmt, Si // 获 取 字 段 的 名 称 


echo "<td bgcolor=#FFFFFF' align='center’ >$ficld name</td>"; 


oci_free_statement($stmt); // 释 放 关 联 于 Oracle 语句 或 游标 的 所 有 资源 
> 

</tr> 
<?php 
Squery="select * from tb_user "; /定义 SQL 语句 
S$result=oci_parse($conn.Squery); // 预 置 Oracle 语句 
S$r = oci_execute(S$result, OCI DEFAULT): /执行 查询 语句 
while($row=oci_fetch_row(S$result){ /while 循环 输出 查询 结果 数组 中 的 数据 
?> 

<tr> 
<?php 


for ($i= 0; $i< $ncols: Sit+) { 


// 根 据 字段 的 列 数 输 出 数据 


echo "<td bgcolor=#FFFFFF' align='center >$row[$il</td>"; 


} 


9 
</r> 
<?php 


oci_close($conn): 
> 


和 秘笈 心 法 


// 关 闭 数据 库 


心 法 领悟 526: 盘点 本 实例 应 用 的 函数 。 
oci_field_name() 函 数 返 回 与 字段 数字 索引 (从 1 开始 ) 相对 应 的 字段 名 ， 即 获取 第 一 个 字段 的 名 称 时 ， 应 
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S$column name = oci ficld name($stmt, $i): /获取 字段 名 称 
Scolumn _precision = oci_field_precision($stmt, $i); /获取 字段 的 精度 
Scolumn scale =oci_field_scale($stmt. $1); // 获 取 字 有 段 的 范围 
S$column type = oci_field type($stmt, $i); /字段 的 数据 类 型 
Scolumn size = oci_field_size($stmt, $i); /获取 字段 的 大 小 


S$column type_raw = oci_field type_raw($stmt., $i); // 获 取 字 段 的 原始 Oracle 数据 类 型 
Pn 


<u> 
<td alipn='eenter bgeolor-"#FFFFFF"><?php echo Seolumn name :7></td> 


<td align="center" bgcolor="#FFFFFF"><?php echo $column_type :2></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $column_size :?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $column_type_raw ;7></td> 


<lt> 
总 
oci_free_statement($stmt); /释放 资源 
oci_close($conn); /关闭 数据 库 
?> 
</table> 


图 秘笈 心 法 

心 法 领悟 327: 获取 数据 表 中 字段 信息 的 函数 。 

获取 数据 表 中 的 字段 信息 并 不 是 一 项 常用 的 技术 ， 它 只 会 出 现在 一 些 特殊 操作 中 ， 例 如 动态 创建 数据 表 、 
在 网 站 的 后 台 管 理 系统 中 查看 数据 表 的 结构 等 。 其 中 只 有 oci_num fields 0 和 oci_field_name() 函 数 可 能 会 经 常 使 
用 ， 有 关 这 些 函 数 的 详细 讲解 请 参考 PHP 手册 。 


高 级 | 


实例 528 趣味 指数 : 请 廊 育 家 | 


力 实例 说 明 
在 本 实例 中 ， 介 绍 一 种 可 以 远程 修改 Oracle 数据 库 用 户 密码 的 方法 ， 其 运行 效果 如 图 12.10 所 示 。 


用 户 登录 Lcgm 


用 户 名 : 


nf 


图 12.10 ”修改 Oracle 数据 库 用 户 的 密码 


图 关键 技术 


修改 Oracle 数据 库 用 户 的 密码 应 用 的 是 oci password_change0 函 数 ， 其 语法 如 下 : 

bool oci_password_change ( resource connection, string usemame, string old_password, string new_password ) 
oci_password_change0) 函 数 用 于 修改 用 户 usermame 的 密码 。 如 果 成 功 返 回 TRUE， 失 败 则 返回 FALSE。 
oci_password_change() 函 数 的 参数 说 明 如 表 12.7 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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bool oci fetch( resouree statement ) 
在 PHP 5.0.0 之 前 的 版 本 必须 使 用 ocifetch0 蔡 代 本 函数 。ocifetch0 函 数 名 仍然 可 用 ， 为 向 下 兼容 作为 
oci_fetch0 的 别名 ， 但 不 推荐 使 用 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 Oracle 数据 库 ， 指 定数 据 库 编码 格式 为 UTF-8， 其 代码 如 下 : 
/机 娄 所 库 名 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
// 如 果 Oracle 数据 库 服务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
Seonmroci comeell gm nmol voracle", "utf8") or dir(oci errorO): 
(2) 新 建 index.php 文件 ， 通 过 PHP 变量 完成 数据 的 循环 输出 。 首 先 包含 数据 库 连接 文件 ， 然 后 定义 SQL 
语句 ， 通 过 oci_define by_name0 函 数 将 SQL 语句 中 查询 出 的 字段 名 称 与 指定 的 变量 进行 绑 定 。 最 后 执行 查询 


操作 ， 通 过 while 语句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 
<?php 


include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$query="select name, position, age from tb_user "; // 定 义 SQL 语句 
$result=oci_parse($conn,$query); // 预 置 Oracle 语句 
oci_define_ by_name($result "NAME", Sname); /将 字段 name 与 变量 $name 绑 定 


oci_define_by_name($result, "POSITION", $position); 
oci_define_ by_name($result "AGE", $age); 
oci_execute($result); /| 执行 查询 操作 
while (oci_fetch(S$result)) { // 循 环 输出 查询 结果 
?> 
<tr> 
<td align="center" valign="middle">&nbsp;</td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo $name:?></span></td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo Sposition:?></span></td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo $age:?></span></td> 
<ltr> 


a 
oci_free_statement($result); /| 释放 空间 
oci_close($conn); /关闭 数据 库 
?> 
国 秘笈 心 法 


心 法 领悟 330: 应 用 oci_define by_name0 函 数 的 注意 事项 。 
(1) Oracle 使 用 大 写字 母 的 列 名 ， 而 用 户 在 select 中 可 以 用 小 写字 母 。 
(2) 如 果 需 要 定义 一 个 抽象 数据 类 型 (LOBIROWID/BFILE) ， 必 须 先 用 oci_new_descriptor0 函 数 分 配 空间 。 


12.3 Oracle 数据 库 应 用 


前 面 只 是 讲解 连接 Oracle 数据 库 的 方法 以 及 一 些 简单 的 操作 ， 在 本 节 中 将 Oracle 数据 库 应 用 到 实际 的 程序 
开发 中 。 


实例 531 起 味 指 数 二 商 页 
实例 说 明 


本 实例 实现 一 个 管理 员 的 注册 功能 ， 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 将 注册 信息 添加 到 指定 的 
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<t> 
<td align="right"> 验 证 码 : </td> 
<td align="left"> 
<input name="check_code" type="text" class="input" id="check_code" size="10" /> 
<input type="hidden" name="defValidatorCode" value="" /> 
<script language="javascript"> 
var num1=Math.round(Math.random()*10000000); 
varnum=numl .toString().substr(0,4); 
document write("<img name=codeimg sre="ValidatorCode php?code="+num+">"); 
forml.defValidatorCode.value=num:; 
function reCode(){ 
var numl=Math.round(Math.random()*10000000); 
var num=numl .toString().substr(0,4); 
document.codeimg.sre="ValidatorCode.php?code="+num: 
form!l .defValidatorCode.value=num; 
3 
</script> 
<a href="javascript:reCode0" class="al"> 看 不 清 </a> 
<itd> 


</tr> 
</table> 
<form> 


(3) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 数据 添加 到 指定 的 数据 表 中 。 在 处 理 密码 时 应 用 MD5 对 密 
码 进 行 加 密 ， 由 于 页 面 中 的 编码 格式 是 UTF-8， 而 Oracle 数据 库 中 使 用 的 是 GB2312， 为 了 避免 数据 输出 时 出 
现 乱码 ， 在 执行 添加 操作 之 前 ， 应 用 iconv0 函 数 将 所 有 提交 的 数据 转换 为 GB2312 编码 ， 其 代码 如 下 : 


<?php 
header ("Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"); 
if($_POST['name']!="" &é& $ Sle "){ 
$sql="insert into tb admin(id.name.pas: 
values(tb_adminid.nextval," iconv(" i Ca POST[name"]).",".mdS(iconv("utf-8","gb2312",$_POST['passD).™,".date("Y-m-d").")"; 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ); 
这 Srsbf 
echo "<script>alert( 管 理 员 添加 成 功 ! '):window location href-index.php?conn_id=1':</script>": 
jelse{ 
echo "<script>alert( 管 理 员 添加 失败 ! ):windwo location href='index.php'</script>"; 
} 


Jelse{ 

a "<script>alert(' 请 输入 管理 员 信 息 ! "):windwo location href="index.php'</script>"; 
} 

by- 


(4) 创建 ValidatorCode.php 文件 ， 定 义 验 证 码 的 实现 方法 ， 详 细 内 容 请 参考 关键 技术 。 
(5) 创建 js 脚本 文件 夹 ， 编 写 check.js 脚本 文件 ， 定 义 chkinput() 方 法 对 表单 中 的 元 素 值 进行 验证 。 


国 秘笈 心 法 


心 法 领悟 531: Oracle 数据 库 中 insert 添加 语句 的 编写 。 
在 创建 数据 表 时 ， 指 定 ID 字段 为 表 的 主键 ， 通 过 序列 完成 主键 ID 值 的 添加 ， 在 本 实例 中 序列 为 
tb_adminid.nextval。 


实例 532 由 朗朗 友信 


国 实例 说 明 


下 面 讲解 Oracle 数据 库 中 管理 员 登 录 功 能 的 实现 , 将 详细 讲解 如 何在 Oracle 数据 库 中 完成 用 户 名 和 密码 的 
验证 操作 ， 本 实例 的 运行 结果 如 图 12.14 所 示 。 
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图 秘笈 心 法 


心 法 领悟 532: 编码 格式 转换 的 必要 性 。 

在 创建 的 Oracle 数据 库 中 ， 数 据 的 编码 格式 是 GB2312， 而 程序 页 面 中 的 编码 格式 是 UTF-8， 所 以 在 执行 
select 查询 语句 时 ， 在 where 条 件 中 ,必须 应 用 iconv0 函 数 对 表单 中 提交 的 用 户 名 和 密码 进行 编码 转换 ， 使 其 与 
数据 库 中 存储 的 数据 编码 统一 ， 这 样 才 可 以 进行 比较 。 否 则 由 于 数据 的 编码 格式 不 同 ， 无 论 输 入 的 用 户 名 和 密 
码 是 否 正确 都 不 能 成 功 登录 。 唯 一 一 种 对 数据 编码 格式 没有 限制 的 情况 就 是 数据 中 不 包含 中 文字 符 串 。 


高 级 
趣味 指数 走 宙 二 从 


图 实例 说 明 


本 实例 在 实现 管理 员 登 录 功 能 的 基础 上 ， 增 加 对 管理 员 数 据 的 更 新 和 删除 功能 。 可 以 对 管理 员 的 名 称 、 密 
码 和 注册 时 间 进 行 更 新 操作 ， 同 时 也 可 以 删除 指定 的 管理 员 数 据 ， 其 运行 结果 如 图 12.15 所 示 。 


管理 本 
REN LILZTIYUAN GUAN LU XI TONC 


肋 称 ”| ”刻本 ”| 注 基本 间 | 操作 
[EE ECDIS | 


12.15 “管理 员 数 据 的 更 新 和 删除 


力 关键 技术 


这 里 仍 应 用 ADODB 连接 、 操 作 Oracle 数据 库 。 以 数据 表 中 数据 的 ID 为 条 件 ， 执 行 update 更 新 和 delete 
删除 语句 。 

在 本 实例 中 ， 管 理 员 登录 成 功 后 ， 应 用 SESSION 会 话机 制 将 登录 的 管理 员 名 称 存储 到 SESSION 变量 中 ， 
通过 这 个 SESSION 来 控制 用 户 的 权限 ， 如 果 是 管理 员 则 可 以 执行 管理 员 数 据 的 更 新 和 删除 操作 ， 否 则 将 给 出 提 
示 信 息 ， 并 跳 转 到 管理 员 登 录 页 面 ， 其 关键 代码 如 下 : 

<php 


session_start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
if($_SESSION['name]!=""){ /判断 管 理 员 的 名 称 是 否 为 空 


include("conn/conn .php"): // 包 含 数据 库 连 接 文件 
这 $_POST['Submit2] 一 "删除 "){ 
$sql="delete from tb admin where id=".$ POST[conn idl"": 
Srst = $conn->execute ( $sql ) or die (‘error: ，. $conn->errorMsg 0 ); 
ifSrsb{ 
echo "<script>alert( 管 理 员 删 除 成 功 ! ");:window location hre 人 ~’main.php':</script>"; 
Jelse{ 


加 载 中 
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SESSION 变量 判断 当前 用 户 是 否 具有 操作 权限 ， 如 果 有 权限 ， 则 可 以 根据 按钮 的 值 执行 更 新 或 者 删除 操作 ， 否 
则 将 给 出 提示 信息 ， 并 跳 转 到 管理 员 登 录 页 面 ， 其 代码 如 下 : 
<?php 


session_start0: 
header ( "Content-type: text/html; charset=utf-8" ); // 设 置 文 件 编码 格式 
这 $ SESSION['namel!="){ 
include("conn/conn.php"); 
isS_POST[Submit2] 一 "删除 "){ 
$sql="delete from tb_admin where id=".$ POST[conn id]"": 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg () ); 
ifSrsbf 

echo "<script>alert( 管 理 员 删 除 成 功 ! ):window ,location href="main.php';</script>"; 
Jelse{ 

echo "<script>alert( 管 理 员 删除 失败 ! ):windwo location_ href='main.php'</script>"; 
} 
} 
这 $_ POST[Submit] 一 "更 新 "){ 
$sql="update tb_admin set 
name=" iconv("utf-8", "gb2312",$_POST[name]).".pass=" :mdsS(iconv("ut-S","gb2312",S_POST['pass']).",dates=".$_POST[ dates']." where 
id="$ POST[conn id]"" 
人 
Srsb{ 

echo "<script>alert(' 管 理 员 更 新 成 功 ! ):window.location hre 人 main.php':</script>": 
yelse{ 

echo "<script>alert( 管 理 员 更 新 失败 ! );:windwo.location href="main.php'</script>"; 
jelse 


{ 
echo "<script>alert( 您 不 具备 管理 员 权限 1 );:windwo.location.href='index.php'</script>"; 
} 


2 


图 秘笈 心 法 

心 法 领悟 533: SESSION 变量 的 应 用 。 

通过 SESSION 变量 的 值 来 判断 当前 用 户 的 权限 是 非常 实用 的 方法 , 其 原理 是 : 在 会 员 或 者 管理 员 登 录 成 功 
后 , 将 登录 的 名 称 或 者 一 个 指定 的 值 赋 给 SESSION 变量 , 由 于 SESSION 变量 可 以 实现 在 不 同 页 面 之 间 的 传递 ， 
所 以 可 以 在 具有 访问 权限 限制 的 页 面 中 判断 这 个 SESSION 变量 的 值 ， 如 果 变 量 值 为 真 ， 则 说 明 这 个 用 户 具有 访 
问 权限 ， 否 则 说 明 当 前 用 户 不 具备 访问 权限 。 


A Oracle 数据 的 分 页 显示 
实例 534 趣味 指教 : 二 真相 从 | 


力 实例 说 明 


在 本 实例 中 ， 同 样 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 其 不 同 之 处 是 将 连接 、 操 作 数 据 库 的 方法 封装 
到 类 中 ， 同 时 将 数据 库 中 数据 的 分 页 方法 也 封装 到 类 中 ， 还 有 通过 Smarty 模板 完成 页 面 的 动静 分 离 。 本 实例 完 
成 数据 库 中 员工 信息 的 分 页 输出 ， 其 运行 结果 如 图 12.16 所 示 。 


兴 采 蚤 工 # 全 每 页 号 示 3 名 竺 3 责 共 3 页 首页 上 一 页 下 一 页 尾 页 


图 12.16 Smarty+ADODB 完成 Oracle 数据 的 分 页 显示 
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图 关键 技术 


本 实例 的 关键 是 应 用 面向 对 象 技术 ， 将 Oracle 数据 库 的 连接 、 操 作 以 及 分 页 方法 都 封装 到 类 中 ， 同 时 还 包 
括 Smarty 模板 的 配置 方法 。 应 用 类 的 实例 化 返回 的 对 象 调用 类 中 方法 ， 完 成 与 Oracle 数据 库 的 连接 、 操 作 和 分 


页 ， 最 终 通过 Smarty 模板 完成 页 面 的 动静 分 离 。 


(1) Oracle 数据 库 连 接 类 ConnDB， 不 但 可 以 连接 Oracle 数据 库 ， 还 可 以 连接 MySQL、SQL Server 和 
Access 数据 库 。 该 类 存储 于 system\system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


class ConnDB{ 

var $dbtype; 

var $host; 

Var $user; 

var Spwd; 

var $dbname; 

var $debug; 

Var $conn; 

function ConnDB($dbtype. $host, $user, S$pwd, $dbname, $debug=false){ 
Sthis->dbtype=$dbtype; 
Sthis->host=$host; 
Sthis->user=$user; 
Sthis->pwd=$pwd: 
Sthis->dbname=$dbname; 
Sthis->debug=$debug; 


a GetConnIdO{ 
require("./adodbS/adodb.ine.php"); 
if($this->dbtype—"oci8" || $this->dbtype—"mysql" || $this->dbtype—"mssql"){ 
if($this->dbtype—"mysql"){ 
Sthis->conn=NewADOConnection("mysql"); 
jelse if($this->dbtype—"mssql"){ 
S$this->conn=NewADOConnection("mssql"); 


Sthis->conn->Connect($this->host. Sthis->user,$this->pwd.$this->dbname); 


jelsef 
Sthis->conn = ADONewConnection("oci8"); 
Sthis->conn->Connect($this->dbname,$this->user,$this->pwd): 


} 

}elscif($this->dbtype—"access"){ 
Sthis->conn=NewADOConnection("access"); 
Sthis->conn->Connect("Driver={Microsoft Access Driver 

(*.mdb)}:Dbq=".$this->dbname.":Uid=".$this->user.";Pwd=".$this->pwd.";"); 

} 


Sthis->conn->Execute("set names utf8"); 
if($this->dbtype—"mysql") 
S$this->conn->debug=$this->debug; 

return $this->conn: 

上 

funetion CloseConnIdO{ 
Sthis->conn->Disconnect(): 

} 

} 


/构造 方法 ， 为 成 员 变量 赋值 


/实现 与 不 同 数据 库 的 连接 并 返回 连接 对 象 
// 调 用 ADODB 类 库 文件 

// 判 断 成员 变量 传递 的 数据 库 类 型 

1/ 判断 如 果 是 MySQL 数据 库 

/执行 与 MySQL 数据 库 的 连接 
/数据 库 连接 的 用 户 、 密 码 


// 建 立 一 个 Oracle 连接 


/判断 如 果 使 用 的 是 Access 数据 库 


/| 执行 连接 Aceess 数据 库 
/设置 数据 库 的 编码 格式 


// 返 回 连接 对 象 


// 定 义 关闭 数据 库 的 方法 
1/ 执行 关闭 的 操作 


(2) 数据 库 操作 类 AdminDB， 执 行 对 Oracle 数据 库 的 操作 语句 ， 如 果 是 select 语句 ， 成 功 则 返回 结果 集 
数组 ， 否 则 返回 FALSE; 如 果 是 update、insert 或 者 delete 语句 ， 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 该 类 


存储 于 system\system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstr,Sconn){ // 定 义 方法 ， 参 数 为 SQL 语句 和 连接 数据 库 返回 的 对 象 

$sqltype=strtolower(substr(trim($sqlstr).0,6)); // 截 取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 

Srs=$conn->Execute($sqlstr): // 执 行 SQL 语句 

if($sqltype—"select"){ // 判 断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRows(); /| 执行 该 语句 ， 获 取 查 询 结 果 
if(count($array)—0 || $rs—false) // 判 断 语 句 是 否 执 行 成 功 

rctum false; // 如 果 查 询 结果 为 0， 或 者 执行 失败 ， 则 返回 FALSE 

clse 
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<td align="center" bgcolor="#FFFFFF">{Util text=$arr[amrid].4}</td> 


图 秘笈 心 法 


心 法 领悟 534: ADODB 类 库 和 Smarty 模板 。 

有 关 ADODB 类 库 的 具体 应 用 将 在 第 13 章 中 进行 详细 讲解 ， 而 Smarty 模板 的 应 用 可 以 参考 本 书 第 14 章 。 
在 本 实例 中 , 封装 数据 库 连接 、 操 作 类 、 分 页 类 和 Smarty 模板 的 配置 类 是 一 个 非常 不 错 的 方法 , 推荐 读者 使 用 ， 
并 且 可 以 对 它 进行 不 断 地 完善 。 例 如 ， 扩 展 其 支持 更 多 的 数据 库 、 更 改 分 页 类 的 方法 以 及 更 改 Smarty 模板 中 配 
置 文件 的 存储 路 径 等 。 


| 
实例 535 起 味 指数 : 裕 页 页 容 


图 实例 说 明 


在 本 实例 中 ,应 用 Oracle 数据 库 的 存储 过 程 技 术 , 实现 对 员工 信息 表 中 数据 的 更 新 操作 , 其 运行 结果 如 图 12.17 
所 示 。 
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12.17 存储 过 程 更 新 员工 信息 


力 关键 技术 


存储 过 程 是 为 执行 一 定 的 任务 而 组 合 在 以 前 的 SQL 和 /或 PL/SQL 语句 集 , 通常 由 以 下 几 部 分 组 成 : 声明 部 
分 、 执 行 部 分 和 异常 处 理 部 分 ， 其 中 执行 语句 是 必需 的 ， 而 其 他 两 部 分 则 是 可 选 的 。 

创建 存储 过 程 的 前 提 条 件 是 用 户 具 有 创建 过 程 的 权限 ， 这 个 权限 可 以 由 DBA 赋予 用 户 ， 其 语法 如 下 : 

GRANT CREATE ANY PROCEDURE TO UserName: 

取消 权限 的 语法 如 下 : 

REVOKE CREATE ANY PROCEDURE FROM UserName: 

Oracle 数据 库 中 创建 存储 过 程 的 语法 如 下 : 

CREATE[OR REPLACE] PROCEDURE procedure_name( 

argumentl[{inloutlin out}] type、 

argumentD[finloutin out] type 

Argument nf {inloutlin out}] type 


和 |as} 

<!-- 类 型 变量 的 说 明 --> 
BEGIN 
<!-- 执 行 部 分 --> 
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[EXCEPTION] 
<!-- 可 选 的 异常 处 理 部 分 -> 
END[procedure_name]; 


参数 说 明 : 

REPLACE: 关键 字 ， 为 可 选 值 ， 多 数 情况 下 会 使 用 。 其 作用 为 创建 存储 过 程 时 ， 如 果 同 名 过 程 已 经 存在 则 
删除 同名 过 程 ， 然 后 进行 创建 操作 。 有 一 点 需要 注意 ， 同 一 用 户 下 的 过 程 是 唯一 标识 的 ， 如 果 创 建 时 不 使 用 
REPLACE 关键 字 ， 当 出 现 同 名 过 程 时 ， 会 给 出 ORA-00955 错误 ， 表 示 名 称 已 经 被 现 有 对 象 使 用 。 

procedure_name: 创建 过 程 的 名 称 ， 它 在 数据 库 中 同一 用 户 下 是 唯一 标识 。 

argument: 过 程 的 参数 名 称 ， 为 可 选 参数 。 

站 、out、in out: 参数 的 模式 ， 默 认 的 模式 为 站。in 模式 为 输入 参数 模式 ， 具 备 只 读 属性 ， 不 可 以 在 执行 过 
程 中 赋值 ，out 模式 为 输出 参数 模式 ，in out 为 输入 /输出 参数 模式 。 

type: 指定 参数 的 数据 类 型 。 其 对 形 参 的 定义 只 可 以 指定 类 型 ， 不 可 以 限定 精度 。 

islas: 该 关键 字 到 BEGIN 关键 字 之 间 为 过 程 的 声明 部 分 。 声 明 包括 类 型 游标、 常量 、 变 量 、 异 常 和 棋 套 
子 程序 的 声明 ， 此 处 不 需 DECLARE 关键 字 ， 而 且 此 声明 部 分 中 声明 的 都 是 本 地 和 局 部 声明 ， 即 过 程 结 束 时 声 
明 终止 。 

BEGIN 关键 字 和 END 关键 字 之 间 为 过 程 的 执行 部 分 ,如 果 过 程 中 存在 异常 处 理 , 则 BEGIN 和 EXCEPTION 
关键 字 之 间 为 过 程 的 执行 部 分 ，EXCEPTION 和 END 关键 字 之 间 为 异常 处 理 部 分 。 

在 本 实例 中 创建 的 存储 过 程 如 下 : 


CREATE OR REPLACE PROCEDURE PROC USER( 
p_id IN integer, 
P_position IN VARCHAR 

)AS 

BEGIN 
‘update tb_user set position=p_position where id=p_id; 

commit; 
END PROC_USER: 


图 设计 过 程 

(1) 创建 conn 文件 ， 编 写 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 包 含 数据 库 连接 文件 ， 应 用 Oracle 函数 读 取 Oracle 数据 库 中 的 数据 ， 并 通过 
while 语句 完成 数据 的 循环 输出 。 创 建 form 表单 ， 完 成 员工 更 新 信息 的 提交 ， 将 更 新 数据 提交 到 index_ok.php 
文件 中 ， 其 关键 代码 如 下 : 

<Iphp 
include("conn/conn.php");: 
Squery="select * from tb_user "; 


Sresult=oci_parse($conn.$query); 
Sr = oci_execute(Sresult OCI DEFAULT): 


while($row=oci_fetch_array($result,OCI_ RETURN_NULLS){ 

?> 

<form id="form<?php echo $row[0]:?>" name="form<?php echo $row[0]:?>" method="post" action="update_ok.php"> 
<u> 


<td align="center" bgcolor="#FFFFFF"><?php echo $row[0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[1]:?></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="position" type="text" value="<?php echo $row[2]:?>" size="15" /> 
<input type="hidden" name="conn_id" value="<?php echo $row[0]:?>" /></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[3]:2></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[4]:?></td> 
<td align="center" bgcolor="#FFFFFF"><input type="submit" name="Submit" value=" 更 新 " /></td> 
<lt> 
</form> 
<?php 


oci_close($conn): 
> 


3) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 调 用 存储 过 程 完 成 员工 信息 的 更 新 操作 ， 其 关键 代 
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码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=utf-8" ): /设置 文件 编码 格式 
include("conn/conn.php"); 
$sql = "BEGIN PROC_USER(:id, :positionj: END:"; // 定 义 SQL 语句 
$stmt = OCIParse($conn, $sql); /执行 SQL 语句 
/执行 绑 定 
OCIBindByName($stmt, ":id", $_ POST[conn id], 4): // 参 数 说 明 : 绑 定 PHP 变量 conn id 到 位 置 :id， 并 设 定 绑 定 长 度 为 4 位 
OCIBindByName($stmt, ":position", $_POST[position]. 50); 
if(OCIExecute($stmt)){ /调用 并 执行 存储 过 程 


echo "<script>alert(' 员 工 信 息 更 新 成 功 !);windowlocation href='index.php';</script>"; 
jelsef 
echo "<script>alert(' 员 工 信 息 更 新 失败 0):window ,location href='index php':</script>"; 
} 
> 


国 秘笈 心 ; 


心 法 领悟 535: 在 PHP 动态 页 中 调用 存储 过 程 。 

首先 定义 SQL 语句 ， 执 行 存储 过 程 中 的 更 新 语句 。 然 后 通过 ociparse0 函 数 配 置 Oracle 语句 预备 执行 。 接 
着 通过 OCIBindByName() 函 数 绑 定 一 个 PHP 变量 到 一 个 Oracle 标识 符 。 最 后 通过 OCIExecute0 函 数 执行 Oracle 
语句 ， 完 成 员工 信息 的 更 新 操作 。 


12.4 _ Oracle 数据 的 导入 和 导出 


本 节 将 介绍 Oracle 数据 库 中 数据 的 导入 、 导 出 方法 。 
高 级 | 
实例 536 起 味 指数 : 袖 女 亦 窑 


实例 说 明 EEC 


本 实例 将 Oracle 数据 库 中 的 数据 表 导 出 到 本 地 磁盘 C 盘 下 的 mrsoft a 6 证 
文件 夹 中 ,并 将 导出 的 文本 文件 命名 为 oracle.dmp。 导 出 的 结果 如 图 12.18 攻 | 
所 示 。 型 ， 1M 文件 修改 日 其 2. 00 好。 [ 卫 我 的 电脑 | 


12.18 ”导出 的 文本 文件 


图 关键 技术 


本 实例 应 用 Oracle 数据 库 中 数据 库 逻 辑 备份 工具 Export。 利用 Export 工具 可 以 在 数据 库 打 开 状态 下 备份 数 
据 库 。Export 把 数据 库 中 的 对 象 导出 到 一 个 二 进 制 文件 中 。 该 工具 也 是 数据 库 间 进行 迁移 的 一 个 工具 。 
Export 有 3 种 方法 : 行 命令 法 、 交 互 式 方法 和 参数 文件 方法 。 下 面 主要 介绍 本 实例 中 使 用 的 参数 文件 方法 。 


将 EXP 命令 的 各 个 参数 放 在 一 个 参数 文件 中 ， 参 数 文件 的 命令 格式 如 下 : 
EXP [用 户 名 | 口令 ] PARFILE = 参数 文件 路 径 及 名 称 


以 下 是 一 个 参数 文件 的 示例 ， 代 码 如 下 : 


FULL=Y 


INDEXES=Y 

其 中 ，FULL 设置 为 Y 时 ， 会 导出 除 SYS 方案 对 象 外 的 所 有 的 方案 对 象 ， 如 果 设 置 为 FULL， 要 求 用 户 有 
EXP_FULL_DATABASE 权限 ; FILE 参数 用 来 设置 导出 文件 的 目录 和 文件 名 ; GRANTS 参数 默认 值 为 Y， 用 来 
设置 是 否 导出 权限 信息 ; INDEXES 参数 默认 值 为 Y， 用 来 设置 是 否 导出 表 和 聚集 的 索引 。 
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力 关键 技术 
(1) 导入 用 户 自身 所 拥有 的 表 ， 其 命令 如 下 : 


imp scott/tiger tables=(name.emp) file=export.dmp 
(2) 当 用 户 要 导出 其 他 方案 的 表 时 ， 必 须 具 备 DBA 角色 ， 或 者 被 赋予 EXP_ FULL DATABASE 角 
命令 如 下 : 
imp system/manger tables=(scott.name, scott.emp) file=exportdmp 
(3) 当 执行 导入 操作 时 ， 用 户 可 以 只 导入 表 结 构 而 不 导入 数据 ， 其 命令 如 下 : 
imp scott/tiger tables=(name, emp) file=export.dmp rows=n 
(4) 当 执 行 导 入 操作 时 ， 如 果 对 象 已 经 存在 就 可 以 只 导入 数据 ， 其 命令 如 下 : 
imp system/manager tables=(scottname,scottemp) file=export.dmp ignore=y 
图 设计 过 程 
(1) 选择 “开始 ”/“ 程 序 ”/“ 附 件 ”/“ 命 令 提 示 符 ” 命 令 ， 进 入 DOS 命令 环境 。 
(2) 在 DOS 提示 符 下 输入 “IMP 用 户 名 | 口令 命令 ”， 将 文本 文件 中 的 数据 导入 到 Oracle 数据 库 中 ， 代 
码 如 下 : 
imp system/mrsoft tables=( tb_user,tb_admin) file= C:\mrsoft\oracle.dmp 


(3) 按 Enter 键 ， 执 行 本 实例 ， 其 运行 结果 如 图 12.20 所 示 。 


[Ey 
并 


图 12.20 文本 文件 中 的 数据 导入 至 Oracle 


力 秘笈 心 法 
心 法 领悟 537: 导入 表 空 间 和 导入 整个 数据 库 。 
通过 import 工具 不 但 可 以 导入 表 ， 还 可 以 将 数据 导入 至 不 同 的 账户 ， 导 入 模式 、 表 空间 和 整个 数据 库 。 
导入 整个 数据 库 是 应 用 import 工具 将 文件 中 的 对 象 及 数据 导入 到 数据 库 中 。 
(1) 执行 导入 时 ， 需 要 导入 数据 库 损坏 前 最 新 的 信息 ， 其 命令 如 下 : 


imp system/manager fall=y file=export. dmp 


(2) 执行 导入 时 ， 需 要 导入 最 新 的 完全 导出 文件 信息 ， 其 命令 如 下 : 


imp system/manager full=y file=export.dmp 
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mi 封装 ADODB 操作 类 
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13.1 封装 ADODB 操作 类 
ADODB 是 Active Data Objects Data Base 的 简称 ， 是 一 种 PHP 存 取 数据 库 的 中 间 函 式 组 件 。 本 节 将 介绍 如 
何 对 ADODB 操作 数据 库 的 方法 进行 封装 ， 从 而 使 通过 ADODB 操作 数据 库 的 方法 更 加 简单 。 


[ED 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 ADODB 类 库 文 件 ， 需 要 读者 自行 下 
载 ， 并 复制 到 本 章 的 13 文件 天 下 ， 将 其 命名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


实例 S55 538 趣味 指数 袖 页 页 容 
图 实例 说 明 


连接 数据 库 类 的 封装 ， 意 味 着 通过 ADODB 连接 不 同 的 数据 库 的 方法 更 加 简单 、 更 容易 更 新 和 修改 。 只 要 
向 类 中 传递 对 应 的 参数 值 ， 即 可 完成 与 不 同 数据 库 服务 器 的 连接 。 在 本 实例 中 ， 以 MySQL 数据 库 服 务 器 为 例 ， 
实现 与 db_database13 数据 库 的 连接 ， 连 接 成 功 后 弹出 提示 信息 ， 其 运行 结果 如 图 13.1 所 示 。 


HH moors 


13.1 ADODB 连接 数据 库 类 


力 关键 技术 


ADODB 连接 数据 库 系统 使 用 ADONewConnection0 函 数 ; 如 果 选 择 持久 化 连接 则 使 用 PConnect0 函 数 ， 如 
果 选 择 非 持 久 化 连接 则 使 用 ConnectO) 函 数 。 
(1) ADONewConnection() 函 数 连接 数据 库 系 统 ， 其 语法 如 下 : 


ADONewConnection($databaseType) 

参数 $databaseType 表示 要 连接 的 数据 库 系 统 的 名 称 ， 如 mysql、mssql 等 。 
(2) PConnect0 函 数 实现 与 数据 库 的 持久 化 连接 ， 其 语法 如 下 : 
PConnect($host,[$user].[$password].[$database]) 

参数 说 明 : 

$host; 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密 码 。 

$database: 使 用 到 的 数据 库 。 

(3) Connect0 函 数 实现 与 数据 库 的 非 持久 化 连接 ， 其 语法 如 下 : 


Conneet(Shost [Suserj[Spassword] [Sdatabasc]) 

参数 说 明 : 

$host: 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 
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Jelse{ 
echo "<script>alert(' 数 据 库 连接 失败 ! );window.location href=index.php';</script>"; 
} 


力 秘笈 心 法 


心 法 领悟 538: 通过 ADODB 连接 数据 库 服务 器 必须 注意 的 问题 。 

定义 连接 数据 库 类 ， 再 定义 连接 方法 GetConnId0 时 ， 必 须 先 通过 require 语句 包含 ADODB 类 库 文件 
adodb.incphp， 和 否则 其 他 一 切 操作 都 无 从 谈 起 。 

建议 在 程序 的 开发 阶段 运用 连接 数据 库 操 作 类 时 ， 将 参数 gdebug 的 值 设置 为 TRUE， 这 样 可 以 返回 执行 的 
SQL 语句 ,便于 获取 SQL 语句 在 执行 过 程 中 出 现 的 错误 。 如 果 是 在 生产 环境 中 运用 连接 数据 库 类 ， 那 么 就 要 将 
$debug 的 值 设 置 为 FALSE。 


高 级 | 


趣味 指数 : 依依 请 六 | 
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力 实例 说 明 


既然 可 以 将 ADODB 连接 数据 库 的 方法 封装 到 类 中 ， 那 么 同样 也 可 以 将 ADODB 操作 数据 库 的 方法 封装 到 
类 中 。 本 实例 介绍 如 何 将 ADODB 操作 数据 库 的 方法 封装 到 类 中 ， 并 且 通 过 该 方法 读 取 MySQL 数据 库 服务 器 
的 db_database13 数据 库 中 tb_bccd 数据 表 中 的 数据 ， 其 运行 结果 如 图 13.2 所 示 。 


Han 

J 名 和 版 本 | 时 间 

1 VC 各 词典 标准 所 | 2010-07-29 
日 LL) 标准 所 | 2010-07-29 
3 Jur 程 词典 标准 所 | 2010-07-29 
‘ Ca 得 问 典 标准 并 | 20lo-07-29 
5 了 编程 词 内 标准 所 | 2010-07-29 
昌 CH 坟 程 亲 奥 标准 类 | 2010-07-29 
7 ET 标准 所 | 2010-07-29 
日 ET 标准 所 | 2010-07-29 
9 各 河内 标 | 2010-07-29 
10 | 办 公 自 动 化 过程 标准 折 | 2010-07-29 
四 硬件 给 护 编程 词典 一 标准 所 | 2010-07-29 
加 电 及 时而 编程 记 内 标准 折 | 2010-07-29 


13.2 ADODB 操作 数据 库 类 


力 关键 技术 


ADODB 操作 数据 库 类 为 AdminDB， 在 操作 数据 库 的 ExecSQL0 方 法 中 ， 关 键 是 以 下 几 个 函数 的 运用 。 
(1)strtolower0 函 数 将 字符 串 转换 为 小 写字 母 ， 其 语法 如 下 : 


string strtolower(string str) 
运用 本 函数 的 目的 是 将 SQL 语句 中 的 字符 串 都 转换 为 小 写 。 
(2) substrO 函 数 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 ， 其 语法 如 下 : 
string substr(string str.int start,int length) 
参数 说 明 : 
str: 指定 截取 的 字符 串 。 
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start: 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末尾 开始 截取 。 
length: 可 选 参 数 ， 指 定 截取 字符 串 的 长 度 。 如 果 为 负数 ， 则 表示 取 倒 数 第 length 个 字符 。 


< 注意 : 本 函数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 一 个 字符 表示 为 0。 


运用 substr0 函 数 对 SQL 语句 中 前 6 个 字符 串 进 行 截取 ， 其 目的 是 获取 SQL 语句 的 类 型 (insert、select 或 
者 update) ， 判 断 其 执行 的 是 什么 操作 。 
(3) trim0 函 数 删除 字符 串 中 首尾 的 空白 或 者 其 他 字符 。 
(4) execute0 函 数 为 ADODB 中 执行 SQL 语句 的 方法 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 失 败 则 
返回 FALSE， 其 语法 如 下 : 
execute($sql[,$inputarr=false]) 
参数 说 明 : 
$sql: 指定 要 执行 的 SQL 语句 。 
$inputarr: 设置 传 入 的 结合 变量 ， 如果 没 有 设置 Sinputarr， 则 $sql 为 普通 的 SQL 语句 ，execute0 函 数 的 格式 如 下 : 


S$connect->execute('select * from tb_user where id= 1) 


如 果 设置 了 $inputarr， 则 execute0) 函 数 的 格式 如 下 : 


S$connect -> execute('select * from tb_user where id = ?array(SvD) 


(5) GetRows() 函 数 是 GetArray0 的 同 义 函数 ， 是 为 了 与 Microsoft ADO 相 容 定义 的 ， 其 语法 如 下 : 


Ry 
返回 从 当前 指针 指向 的 记录 开始 , 到 $number_of rows - 1 行 的 全 部 记录 的 数组 。 参数 $number_of rows 表示 
指定 的 记录 行 ， 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停 止 。 


图 设计 过 程 
(1) 创建 found.database.php 文件 ， 定 义 数据 库 操作 类 AdminDB， 定 义 ExecSQL0 方 法 ， 根 据 传 递 的 SQL 
语句 执行 对 数据 库 的 操作 。 在 ExecSQL0 方 法 中 ， 应 用 substr0 函 数 获取 参数 传递 的 SQL 语句 的 类 型 ， 然 后 根据 


SQL 语句 的 类 型 进行 判断 , 如 果 是 select 查询 语句 , 则 执行 GetRow() 方 法 , 获取 查询 结果 ; 如 果 是 update 、insert 
或 者 delete 语句 ， 则 直接 返回 TRUE 或 者 FALSE， 其 代码 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstrSconn){ /定义 方法 ， 参 数 为 SQL 语句 和 连接 数据 库 返回 的 对 象 
$sqltype=strtolower(substr(trim($sqlstr).0,6)); /截取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 
Srs=$conn->Execute($sqlstr); /执行 SQL 语句 
if($sqltype=—"select"){ // 判 断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRows(); // 执 行 该 语句 ， 获 取 查 询 结果 
if(count($array)—0 || $rs—false) // 判 断 语句 是 否 执行 成 功 
retum false: // 如 果 查 询 结果 为 0 或 者 执行 失败 ， 则 返回 FALSE 
else 
return $array; // 否 则 返回 查询 结果 的 数组 


}elseif ($sqltype—"update" || $sqltype 一 "insert" || $sqltype—"delete"){ 
// 判 断 如 果 SQL 语句 类 型 不 为 select、 则 执行 如 下 操作 


if($rs) 

Teturn true; // 执 行 成 功 返 回 TRUE 
else 

return false; // 否 则 返回 FALSE 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB 和 数据 库 操作 类 AdminDB， 其 关键 代 
码 如 下 : 


<?php 
require("found.database.php"); // 包 含 类 文件 
Sconnobj=new ConnDB("mysql"."localhost". "root"."111"."db_database13".false): // 实 例 化 数据 库 连接 类 
$conn=$connobj->GetConnId(): // 返 回 连接 标识 
$admindb=new AdminDB(): // 实 例 化 数据 库 操作 类 


744 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 


Snrows: 每 页 显示 的 记录 数 。 
Spage: 保存 当前 页 数 ， 默 认为 1。 


(2) AbsolutePage0 函 数 返 回 当 前 页 的 页 数 ， 其 语法 如 下 : 
AbsolutePage(Spage=-]) 


该 函数 要 与 PageExecute() 函 数 配合 使 用 。 
(3) AtFirstPage() 函 数 为 如 果 当 前 页 是 第 一 页 ， 则 返回 TRUE， 其 语法 如 下 : 


AtFirstPage($status=") 
该 函数 要 与 PageExecute0) 函 数 配 合 使 用 ， 判 断 当前 是 否 为 第 一 页 。 
(4) AtLastPage0 函 数 判 断 当前 页 是 否 为 最 后 一 页 ， 其 语法 如 下 : 


AtLastPage($status="); 
该 函数 同样 要 与 PageExecute0 函 数 配 合 使 用 ， 判 断 当前 页 是 否 为 最 后 一 页 ， 如 果 是 则 返回 TRUE。 
本 实例 中 整合 了 上 述 几 个 ADODB 类 库 中 的 函数 ， 封 装 了 一 个 ADODB 分 页 类 。 


图 设计 过 程 
(1) 创建 found.database.php 文件 ， 定 义 SepPage 分 页 类 ， 定 义 ShowData0 方 法 ， 读 取 数 据 库 中 存储 的 数 


据 ， 并 且 将 查询 结果 返回 到 数组 中 。 定 义 ShowPage0 方 法 ， 创 建 分 页 超 链 接 ， 完 成 从 数据 库 中 读 取 数 据 的 分 页 
输出 。SepPage 分 页 类 的 关键 代码 如 下 : 


class SepPage{ 
Var $rs; 
var Spagesize; 
Var $nowpage; 
var $array; 
Var $conn; 
Var $sqlstr 
function ShowData(Ssqlstr.Sconn.$pagesize,Snowpagcj{ /定义 方法 
ifl!isset(Snowpage) || Snowpage—"") // 判 断 变 量 值 是 否 为 空 
Sthis->nowpage=1; // 定 义 每 页 起 始 页 
clse 
Sthis->nowpage=$nowpage: 
Sthis->pagesize=$pagesize; // 定 义 每 页 输出 的 记录 数 
Sthis->conn=$conn; // 连 接 数 据 库 返 回 的 标识 
$this->sqlstr=$sqlstr /执行 的 查询 语句 
Sthis->rs=$this->conn->PageExecute($this->sqlstr,$this->pagesize. $this->nowpage); 
@$this->array=$this->rs->GetRows(); // 获 取 记 录 数 
if(eount($this->array)==0 || $this->rs—false) 
Teturn false; 
else 
Tetum $this->array: 
} 
/| 省略 了 ShowPage0 方 法 中 的 内 容 
} 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB、 数 据 库 操作 类 AdminDB 和 分 页 类 
SepPage， 其 关键 代码 如 下 : 
< 


php 
require("found.database.php"); // 包 含 类 文件 
S$connobj=new ConnDB("mysql"."localhost". "root"."111"."db_database13".false): // 实 例 化 数据 库 连 接 类 
S$conn=$connobj->GetConnId(): 
S$admindb=new AdminDB0: // 实 例 化 数据 库 操作 类 
S$seppage=new SepPage(): /实例 化 分 页 类 
> 


(3) 创建 index.php 文件 ， 包 含 connect.database.php 文件 ， 调 用 分 页 类 中 的 ShowData() 方 法 ， 完 成 数据 的 
分 页 输出 ， 调 用 分 页 类 中 的 ShowPage0 方 法 输出 分 页 的 超 链接 ， 其 关键 代码 如 下 : 


<?php 

include_once 'conn/connect.database.php'; // 调 用 类 中 方法 
Sarray=$seppage->ShowData("select + from tb_user".$Sconn,10.$_GET["page"]); /| 分 页 读 取 数据 库 中 数据 
for($i=0;$i<count($array):$i++){ /| 循环 输出 数据 库 中 数据 
> 
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ADODB 类 库 中 提供 的 ADODB pager 类 实现 分 页 功能 ， 分 页 输出 编程 词典 的 注册 用 户 ， 其 运行 结果 如 图 13.5 
所 示 。 


| 


必 39 首页 上 -页 下 -页 尾 页 


13.5 ADODB pager 分 页 类 


力 关键 技术 


ADODB_Pager0 函 数 是 ADODB_Pager 类 的 构造 函数 ， 通 过 类 中 的 render0 函 数 可 以 实现 分 页 功能 ， 其 语法 
如 下 : 


ADODB_ Pager(Seonn, $sql, Sid = 'adodb' SshowPageLinks = false) 
参数 $conn 是 数据 库 连 接 对 象 ， 参数 $sql 是 执行 的 SQL 语句 ;参数 $id 为 每 个 分 页 的 id 号 ; 参数 
$showPageLinks 设置 是 否 显 示 各 个 页 的 链接 ， 默 认为 FALSE。 


安 提示 : 应 用 ADODB_pager() 函 数 实现 分 页 功能 的 前 提 条 件 是 必须 载 入 adodb-pager.ini.php 文件 。 
图 设计 过 程 

(1) 创建 com 文件 夹 ， 编 写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_database13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 UTF-8， 其 代码 如 下 : 


<Iphp 


include_once ('../adodb$/adodb.ine.php’); // 载 入 (include) adodb.ine.php 文件 
$conn = ADONewConnection('mysql); /建立 连接 

$conn -> PConnect('localhost,root"111'db_database130): /连接 数据 库 

$conn -> execute('set names utf8"); // 设 置 编码 格式 


> 


(2) 创建 index.php 文件 ， 完 成 数据 的 分 页 输出 。 首 先 包含 数据 库 连接 文件 ， 然 后 载 入 adodb-pager.ini.php 
文件 ， 最 后 实例 化 ADODB_Pager 类 ， 调 用 Render0 方 法 ， 设 置 每 页 显示 10 条 记录 ， 其 关键 代码 如 下 : 


< 


include ‘conn/conn.php'; // 载 入 数据 库 连 接 文件 
include_once ' adodb-pager ine.php'; // 载 入 adodb-pageriiniphp 文件 
诈 声明 对 象 */ 


S$pager = new ADODB_Pager($conn,"select id.user as ' 用 户 名 ', pass as ' 密 码 ',dates as ' 注 册 时 间 ' from tb_user"); 
履 ”调用 Render0 函 数 确定 每 页 显示 多 少 记录 */ 

Spager -> Render(10): 

> 


力 秘笈 心 法 

心 法 领悟 542: 修改 ADODB_Pager 类 中 定义 的 分 页 方法 的 样式 。 

修改 ADODB_Pager 类 中 定义 的 分 页 方法 的 样式 ， 即 对 载 入 的 adodb-pager.ini.php 文件 进行 修改 。 可 以 修 
改 的 内 容 包括 超 链 接 、 表 格 背 景 、 宽 度 、 边 框 宽度 和 颜色 等 。 在 本 实例 中 ， 将 超 链接 修改 为 中 文 并 且 重 新 定 
义 了 表格 的 宽度 。 为 了 便于 读者 使 用 , 还 将 修改 后 的 adodb-pager.iniphp 从 ADODB 类 库 中 复制 到 实例 的 根 目 
录 下 。 
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力 实例 说 明 


通过 ADODB 类 库 操 作 数据 库 ， 不 但 要 掌握 数据 库 的 连接 方法 ， 还 要 掌握 操作 结果 集 的 方法 。 在 本 实例 中 
将 介绍 ADODB 类 库 中 操作 结果 集 的 方法 ， 并 且 应 用 其 中 的 方法 循环 输出 数据 表 中 的 字段 和 值 ， 其 运行 结果 如 
13.6 所 示 。 


图 13.6 ADODB 操作 结果 集 的 方法 


力 关键 技术 


当 使 用 execute0) 函 数 执行 SQL 指令 时 ， 会 回 传 一 个 ADORecordSet 对 象 。 通 过 对 ADORecordSet 对 象 的 控 
制 ， 可 以 对 结果 集 进行 很 多 操作 。 操 作 结果 集 的 方法 如 下 : 
(1) fields 
该 变量 保存 的 是 当前 指针 所 指向 的 记录 。 
(2) EOF 
该 变量 记录 当前 指针 是 否 指向 最 后 一 条 记录 。 如 果 是 ， 则 设 定 为 TRUE， 否 则 为 FALSE。 
(3) GetArray([$number_of rows]) 
返回 从 当前 指针 指向 的 记录 开始 ， 到 $number_of rows-1 行 的 全 部 记录 的 数组 。 参 数 $number_of rows 表示 
指定 的 记录 行 ， 如 果 没 有 给 出 则 一 直到 EOF 才 停 止 。 
(4) MoveNextO 
函数 作用 : 将 ADORecordSet〔 结 果 集 〉 的 指针 下 移 一 位 。 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
(5) Move($to) 
函数 作用 : 将 ADORecordSet (结果 集 ) 的 指针 移动 到 指定 位 置 。 如 果 $to 等 于 0， 则 指针 指向 结果 集 的 第 
一 条 数据 ， 如 果 $to 的 值 大 于 结果 集 ， 则 指针 指向 最 后 一 条 数据 。 注 意 ， 这 里 的 变量 $to 只 能 是 绝对 定位 。 
(6) MoveFirstO 
函数 作用 : 将 指针 移动 到 第 一 条 数据 ， 等 同 于 Move(0)。 
(7) MoveLast0 
函数 作用 : 将 指针 移动 到 最 后 一 条 数据 ， 等 同 于 Move(RecordCount0-1) 
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PHP 开发 实例 大 全 〈 基 础 卷 ) 
Stype = $fields->type: 
> 
‘<td bgcolor="#FFFFFF"> 
<?php 
/从 对 象 中 获取 字段 的 类 型 信息 


证 (Srst>metaType ( $type, - 1, $fields ) — "T") // 如 果 标 准 类 型 为 
echo $conn->DBDate ( $rst->fields [$i] ); // 使 用 DBDate0 函 数 格式 化 时 间 


echo Srst->fields [$i]: // 如 果 是 其 他 类 型 ， 直 接 输出 
?> 
<htd> 
Fe 


} 
?> 


图 秘笈 心 法 


心 法 领悟 543: 操作 结果 集 方法 的 运用 。 

在 本 实例 中 ， 只 是 使 用 FieldCount0 函 数 和 FetchField0 函 数 对 数据 表 中 的 字段 进行 操作 。 在 实例 544 中 ， 
将 应 用 EOF 、fields 和 movenext0 函 数 以 及 while 语句 完成 数据 表 中 数据 的 循环 输出 , 其 实现 的 是 结果 集中 行 的 
操作 。 


BE 


力 实例 说 明 


在 实例 543 中 介绍 了 很 多 操作 结果 集 的 方法 ， 本 实例 继续 应 用 上 一 实例 中 介绍 的 操作 结果 集 方法 ， 对 数据 
表 中 的 行进 行 操作 ， 循 环 输出 数据 表 中 的 数据 。 同 时 应 用 一 个 新 的 方法 ， 实 现 对 结果 集 存 取 方 式 的 控制 ， 其 运 
行 结果 如 图 13.7 所 示 。 


高 级 
赤 味 指数 : 请 庚 育 安 


ED 《a> 
图 13.7 ADODB 类 库 中 对 数据 库 中 数据 输出 的 控制 


力 关键 技术 


在 通过 对 SQL 语句 的 操作 之 后 ， 多 数 都 会 返回 一 个 结果 集 (ADORecordSet 对 象 ) 。 通 过 对 ADORecordSet 
对 象 的 控制 ， 可 以 对 结果 集 进行 各 项 操作 ， 这 里 介绍 的 是 如 何 控制 结果 集 的 存 取 方 法 。 
1. SADODB_COUNTRECS 


当 该 变量 为 TRUE 时 ，RecordCount0 函 数 会 在 数据 库 驱 动 不 支 持 select 指令 返回 的 记录 总 数 时 进行 自动 模 
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图 设计 过 程 


(1) 创建 conn 文件 ， 编 写 conn.php 文件 ， 完 成 与 两 个 数据 库 服 务 器 的 连接 ， 其 代码 请 参考 关键 技术 中 的 
内 容 。 

(2) 创建 index.php 文件 , 将 从 MySQL 数据 库 中 读 取出 的 数据 通过 GetInsertSQLO 函 数 添 加 到 Access 数据 
库 中 ， 并 且 在 本 页 中 输出 MySQL 数据 库 中 的 数据 ， 同 时 创建 导出 和 查看 Aceess 数据 库 中 数据 的 超 链 接 ， 其 关 


键 代码 如 下 : 

<2php 
include ("conn/conn.php"); 
$sql = "select * from tb_user where id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ): // 执 行 查询 语句 
Sarray = array (); 
while ( ! S$rst->EOF ) { 

Sarray [id] = $rst->fields ['id']:; # process Sarr 

Sarray [user]= iconv ( "utf-8", "gb2312", $rst->fields [user] ); # process Sarr 

ee pe 

Sarray [dates] = $rst->ficlds ['dates']; # process Sarr 

这 ($_GET ['insert] 一 "导出") { 


$sqls = "select * from tb_user where id=0 "; // 创 建 SQL 语句 
Sret = $con->execute ( $sqls ) or die (‘error: '. $con->errorMsg 0 ); // 执 行 查询 语句 
Sinsert = $con->getInsertSQL ( $ret, $array ) or die (update error: '. $con->errorMsg () ); /添加 新 数据 


Scon->execute ( $insert ); 


} 
?> 
<tr> 
<td><?php echo Srst->ficlds [id]; ?></td> 
<td height="20"><?php echo Srst->ficlds ['user']; 2></td> 
<td><?php echo Srst->ficlds [dates ?></td> 
</t> 


<?php 


Srst->movenext (); /指针 下 移 
ee 0: /关闭 连接 
Sn 0; 
3) 创建 access.php 文件 ， 包 含 数据 库 连 接 文 件 conn.php， 完 成 Access 数据 库 中 数据 的 循环 输出 。 
图 秘笈 心 法 


心 法 领悟 545: 通过 ADODB 连接 Access 数据 库 。 

通过 ADODB 连接 Access 数据 库 时 ， 在 设置 数据 库 文件 的 存储 位 置 时 ， 必 须 指定 数据 库 文件 在 服务 器 中 的 
绝对 路 径 。 同 时 为 了 Access 数据 库 文 件 的 安全 ， 可 以 为 Access 数据 库 设 置 密码 。 

选择 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 可 设置 Access 数据 库 的 密码 ;选择 
Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ”命令 ， 在 弹出 的 “撤销 数据 库 密码 ”对 话 框 中 输入 设 
置 时 的 密码 ， 即 可 撤销 该 数据 库 的 密码 。 


实例 546 趣味 指教 走 丰 让 向 | 


力 实例 说 明 


在 MySQL 数据 库 中 有 一 个 limit 关键 字 ， 通 过 它 可 以 控制 select 查询 语句 从 第 几 条 记录 开始 查询 及 查询 多 
少 条 记录 。 而 在 ADODB 中 也 有 一 个 limit 关键 字 ， 就 是 SelectLimit0 函 数 ， 它 模拟 limit 关键 字 ， 控 制 select 查询 
语句 的 执行 。 在 本 实例 中 就 应 用 SelectLimit0 函 数 , 查询 班级 中 前 3 名 学 生 的 成 绩 , 其 运行 结果 如 图 13.10 所 示 。 
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心 法 领悟 546: 明确 SelectLimit0 函 数 与 MySQL 数据 库 中 limit 关键 字 的 区 别 。 
在 SelectLimitO 函 数 中 ，$numrows 指定 的 是 要 查询 的 记录 数 ，$offset 指定 从 第 几 条 记录 开始 查询 ， 而 在 
MySQL 数据 库 中 ，limit 关键 字 指定 查询 的 开始 位 置 ， 而 offset 指定 查询 的 记录 数 。 


力 实例 说 明 


在 ADODB 类 库 中 ， 有 一 种 方法 可 以 返回 表格 式 的 结果 集 ， 即 将 查询 结果 直接 以 表格 的 形式 进行 输出 。 本 
实例 就 应 用 这 种 方法 循环 输出 编程 词典 的 数据 ， 其 运行 结果 如 图 13.11 所 示 。 


高 级 


J 
| 
趣味 指数 : 本 


序号 名 称 类 别 时 间 


1 VC 议程 间 典 标准 版 
2 VB 编程 闻 典 标准 版 
3 JAVA 编 程 闻 奥 标准 版 


图 13.11 ADODB 生成 HTML 表格 


图 关键 技术 


本 实例 应 用 rs2html0 函 数 返回 一 个 HTML 表格 格式 的 结果 集 ， 其 语法 如 下 : 
function rs2html($adorecordset [Stableheader_ attributes]. [Scol_titles]) 


参数 说 明 : 

$adorecordset: 要 返回 的 结果 集 。 

S$tableheader_attributes: 对 表格 的 参数 及 属性 的 设置 。 

$col_titles: 对 字段 的 重新 命名 。 

要 运用 本 函数 ， 必 须 载 入 ADODB 类 库 中 的 tohtml.inc.php 文件 。 


图 设计 过 程 
(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 包 含 数 据 库 连 接 文 件 ， 定 义 SQL 查询 语句 ， 应 用 rs2html0 函 数 将 查询 结果 以 表 
格 的 形式 输出 ， 其 关键 代码 如 下 : 
<php 


include_once ‘conn/conn.php'; // 载 入 数据 库 连接 文件 

include_once '../adodb5S/tohtml inc.php'; // 载 入 tohtmlinc.php 文件 

S$rst = $conn -> execute('select + from tb_becd"): // 返 回 查询 结果 集 

Ts2html($rst' width="775" border="1" cellpadding="1" cellspacing="1" bordercolor=" 考 FFFFF" bgcolor"#CCCCCC",array( 序 号 名 称 '' 类 别 '" 时 间 
六 

> 


图 秘笈 心 ; 
心 法 领悟 547: rs2html0 函 数 。 
这 是 一 个 独立 的 函数 (rs2heml = recordset to html) ， 相 当 于 PHP 中 的 odbc result_all0 函 数 。 它 输出 一 个 完 
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在 本 实例 中 运用 的 并 不 是 关键 技术 中 讲解 的 GetMenu0 函 数 而 是 GetMenu20 函 数 。GetMenu20) 函 数 的 作 
用 与 GetMenu0 函 数 相 同 ， 它 们 之 间 的 区 别 是 : GetMenu0 中 的 参数 Sdefault_str 和 fields[0] 比 较 ， 如 果 相 等 ， 
那么 fields[0] 就 是 这 个 下 拉 列 表 框 的 默认 选项 ， 而 GetMenu20 中 的 参数 $default_str 则 是 和 fields[1] 进 行 比较 ， 
其 他 不 变 。 


es 
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力 实例 说 明 


事务 处 理 机 制 在 程序 开发 过 程 中 有 非常 重要 的 作用 ， 它 可 以 使 整个 系统 更 加 安全 ， 例 如 在 银行 处 理 转账 业 
务 时 ， 如 果 A 账户 中 的 金额 刚 被 发 出 ， 而 B 账户 还 没 来 得 及 接受 就 发 生 停电 事故 ， 这 会 给 银行 和 个 人 带 来 很 
大 的 经 济 损失 。 采 用 事务 处 理 机 制 一 旦 在 转账 过 程 中 发 生意 外 ， 则 程序 将 回 滚 不 做 任何 处 理 。 在 本 实例 中 ， 沿 
用 实例 545 的 内 容 , 实现 数据 在 不 同 数据 库 间 的 转换 功能 , 在 将 MySQL 数据 库 中 的 数据 转换 到 Access 数据 库 
中 后 ， 删 除 MySQL 数据 库 中 的 原始 数据 ， 并 应 用 事务 处 理 机 制 保证 数据 转换 操作 安全 、 顺 利 地 进行 。 运 行 本 
实例 ， 如 图 13.13 所 示 ， 单 击 “数据 转 移 ” 超 链接 ， 将 MySQL 数据 库 中 的 数据 转移 到 Access 数据 库 中 ， 并 且 
删除 MySQL 数据 库 中 的 原始 数据 。 单 击 “ 查 看 ACCESS” 超 链接 ， 将 查看 到 Access 数据 库 中 存储 的 数据 ， 如 
图 13.14 所 示 。 
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图 13.13 数据 转移 13.14 ”查看 Access 数据 库 中 的 数据 


力 关键 技术 


在 ADODB 中 ， 事 务 处 理应 用 的 是 如 下 3 个 函数 : 

(1) BeginTrans0 函 数 ， 开 启事 务 处 理 。 该 函数 和 下 面 的 两 个 函数 都 是 应 用 在 PHP 的 事务 处 理 中 。 

(2) CommitTrans0 函 数 ， 如 果 成 功 完成 数据 库 操作 则 执行 该 函数 。 

(3) RollbackTrans0 函 数 ， 结 束 一 次 操作 ， 恢 复 操 作 前 的 所 有 改变 。 如 果 成 功 返 回 TRUE， 如 果 服 务 器 不 
支持 则 返回 FALSE。 


图 设计 过 程 
(1) 创建 conmn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 编写 index.php 文件 ， 包 含 数据 库 连接 文件 ， 定 义 SQL 语句 ， 循 环 输出 MySQL 数据 库 中 的 数据 ， 通 


过 BeginTrans() 函 数 开 启事 务 处理 。 然 后 根据 超 链接 传递 的 参数 进行 判断 ， 通 过 GetInsertSQLO 函 数 执 行 数据 的 
转移 操作 ， 转 移 成 功 后 通过 delete 语句 删除 原始 数据 库 中 的 数据 。 最 后 根据 添加 语句 和 删除 语句 的 执行 情况 ， 
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判断 是 执行 CommitTrans 0 提交 操作 还 是 执行 RollbackTrans 0 回 滚 操作 ， 其 关键 代码 如 下 : 


<php 

include ("conn/conn.php"): 

$sql = "select* from tb_user where id order by id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ); /| 执行 查 询 语句 
Sarray = array (); 

$con->BeginTrans (); // 开 始 事务 处 理 
S$conn->BeginTrans (); // 开 始 事务 处 理 


while ( !Srst->EOF ) { 
站 ($_GET ['insert] 一 "数据 转移 ") { 
Sarray [id] = S$rst->fields [id"l; # process $arr 
Sarray [user] = iconv ( "utf-8", "gb2312", $rst->fields [user] ); # process Sarr 
Sarray ['pass'] = $rst->fields [pass']; # process $arr 
Sarray [dates] = $rst->fields ['dates']; # process $arr 
$sqls = "select * from tb_user where id=0 "; /创建 SQL 语句 
Sret = $con->execute ( $sqls ) or die ('emror: '. $con->errorMsg 0 ); // 执 行 查询 语句 
Sinsert = $con->getInsertSQL ( $ret, $array ) or die ( update error: '. $con->errorMsg 0 ); /添加 新 数据 
Sresult=$con->execute ( $insert ); 
$sql ='delete from tb_user where id = . Srst->ficlds [id]: JWSQL 删除 语句 
Sresults = $conn->execute ( $sql ) or die ( 'execute error: '. $conn->ErrorMsg 0 ); /执行 删除 语句 


?> 
<t> 
<td><?php echo Srst->ficlds ['id']: ?></td> 
<td height="20"><?php echo S$rst->ficlds [user]; ?></td> 
<td><?php echo Srst->ficlds ['dates]; ?></td> 


<t> 
<?php 
S$rst->movenext (); /指针 下 移 
} 
if(Sresul){ 
$con->CommitTrans (); /执行 提交 
证 (Sresults) { 
S$conn->CommitTrans 0: /| 执行 提交 
}else{ 
S$conn->RollbackTrans 0: /| 执行 回 滚 操作 
jelse{ 
$con->RollbackTrans (); /| 执行 回 滚 操作 
} 
S$rst->close 0; // 关 闭 连接 


Sconn->close |; 
?> 


(3) 创建 access.php 文件 ， 循 环 输出 Access 数据 库 中 存储 的 数据 。 
国 秘笈 心 法 

心 法 领悟 549: 什么 是 事务 。 

事务 是 指 一 个 或 一 系列 的 查询 ， 这 些 查询 或 者 全 部 执行 或 者 全 部 不 执行 ， 其 作用 是 在 服务 器 发 生 错误 或 崩 
溃 的 情况 下 确保 数据 库 的 一 致 性 。 

一 个 事务 被 永久 地 写 入 到 数据 库 中 称 为 事务 提交 ， 将 状态 重 置 到 事务 开始 之 前 的 状态 称 为 事务 回 滚 。 事 务 
具有 以 下 4 个 特性 : 

(1) 原子 性 : 指 事务 作为 一 个 整体 或 者 完全 执行 ， 或 者 完全 不 执行 。 

(2) 一 致 性 : 指 一 个 事务 必须 能 够 使 数据 处 于 一 致 的 状态 。 

(3) 孤立 性 : 在 事务 完全 完成 之 前 ， 它 们 都 是 孤立 的 。 

(4) 持续 性 : 一 旦 写 入 数据 库 后 ， 事 务必 须 是 永久 的 、 持 续 的 。 
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13.3 ADODB 中 的 错误 处 理 


力 实例 说 明 

ADODB 提供 很 多 操作 数据 库 的 方法 和 函数 ， 这 其 中 不 乏 错误 处 理 机 制 和 程序 调试 的 方法 。 在 本 实例 中 将 
介绍 一 种 程序 调试 的 方法 。 通 过 该 方法 将 输出 程序 中 执行 的 SQL 语句 ， 如 果 SQL 语句 编写 错误 ， 那 么 将 输出 
错误 信息 ， 其 运行 效果 如 图 13.15 所 示 。 


(mysql): select * from 由 use where id limit 5 


图 13.15 输出 SQL 语句 中 的 错误 信息 


图 关键 技术 


输出 系统 中 执行 的 SQL 语句 ,应 用 的 是 ADODB 中 的 debug 变量 。 如 果 变 量 被 设 定 为 TRUE， 当 有 输出 
操作 时 ， 同 时 也 输出 调试 信息 ; 如 果 启 用 debug 变量 ， 当 错误 发 生 时 ， 将 自动 调用 ErrorMsgO 函 数 返 回 错 误 
信息 。 

ErrorMsg0 函 数 返 回 最 后 的 状态 或 出 错 信息 , 即使 没有 错误 发 生 , 也 会 返回 一 个 字符 串 。 所 以 ,一般 情况 下 ， 
只 有 在 发 生 错误 时 (返回 FALSE) 才 调用 该 函数 。 


图 设计 过 程 
(1) 创建 conmn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 编写 index.php 文件 。 首 先 包 含 数据 库 连接 文件 ， 设 置 debug 变量 的 值 为 TRUE， 开 启 调试 功能 。 然 
后 定义 SQL 语句 ， 循 环 输出 MySQL 数据 库 中 的 数据 。 最 后 关闭 连接 和 数据 库 ， 其 关键 代码 如 下 : 
php 


include ("conn/conn php");: 


$conn -> debug = true; /开启 调试 
$sql = "select * from tb_use where id limit 5 "; /| 创建 SQL 语句 
S$ret = $conn->execute ( $sql ) ; /执行 查询 语句 
while ( ! $ret->EOF ) { // 循 环 输出 
?> 
<t> 
<td height="20"><?php echo $ret->fields[0]: ?></td> 
<td height="20"><?php echo $ret->fields[1]: «~ ?></td> 
<td><?php echo $ret->fields[3]; ?></td> 
</tr> 
<?php 
Sret->movenext (); // 指 针 下 移 
Sret->close 0: /| 关闭 连接 
$conn->close (): 
> 
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图 秘笈 心 法 


心 法 领悟 550: 合理 地 运用 debug 调试 功能 。 

debug 变量 的 调试 功能 适合 在 程序 开发 过 程 中 运用 ， 通 过 它 可 以 及 时 发 现 SQL 语句 中 的 错误 。 但 是 在 实际 
的 应 用 环境 中 ， 必 须 关 闭 该 调试 功能 。 为 了 确保 程序 数据 库 的 安全 ， 如 果 存 在 SQL 语句 的 错误 ， 最 好 不 要 让 浏 
览 者 看 到 。 


图 实例 说 明 

本 实例 将 介绍 ADODB 类 库 中 另外 一 种 程序 调试 的 方法 , 该 方法 可 以 在 
程序 发 生 错 误 时 返回 错误 信息 ， 其 效果 如 图 13.16 所 示 。 

关键 技术 图 13.16 返回 错误 信息 


ErrorMsg0 函 数 返 回 最 后 的 状态 或 出 错 信息 ， 即 使 没有 错误 发 生 也 会 返回 一 个 字符 串 。 所 以 多 数 情 况 下 ,其 
与 die0 函 数 联 合 使 用 ， 在 执行 的 SQL 语句 发 生 错 误 时 (返回 FALSE) 才 调 用 该 函数 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 编写 index.php 文件 。 首 先 包 含 数据 库 连 接 文件 。 然 后 定义 SQL 语句 ， 通 过 execute() 函 数 执行 SQL 


语句 , 应 用 die0 函 数 在 SQL 语句 的 执行 发 生 错 误 时 , 调用 ErrorMsg0 函 数 返 回 错误 信息 。 最 后 循环 输出 MySQL 
数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


和 | 


起 味 指数 : 页 庚 页 宙 | 


Frrergsg 返 回 铺 误 信息 


Te dh_taabaselitn os dotsrt exst 
四 。 用 记名 时 间 


<?php 
include ("conn/conn.php"); 
$sql = "select * from tb_use where id limit 5 "; // 创 建 SQL 语句 
Sret = $conn -> execute($sql) or die($conn -> ErrorMsgO); // 执 行 查询 语句 并 返回 错误 信息 
while (! $ret->EOF ) { /循环 输出 
> 
<t> 


<td height="20"><?php echo Sret->ficlds[0]: a ?></td> 
<td height="20"><?php echo Sret->ficlds[1]: ?></td> 
<td><?php echo $ret->fields[3]; ?></td> 

</tt> 


<?php 
Sret->movenext (); /指针 下 移 


} 

Sret->close (): // 关 闭 连 接 
Sconn->close (); 

> 


图 秘笈 心 法 


心 法 领悟 551: 合理 地 运用 ErrorMsgO 函 数 返回 SQL 语句 的 错误 信息 。 

ErrorMsg0 函 数 返回 最 后 的 状态 或 出 错 信息 ， 其 特点 是 无 论 SQL 语句 是 否 出 错 都 会 返回 一 个 字符 串 ， 这 就 
要 求 在 应 用 ErrorMsg0 函 数 时 必须 注意 。 为 避免 在 SQL 语句 执行 正确 的 情况 下 返回 字符 串 , 在 SQL 语句 的 执行 
发 生 错误 时 运用 ErrorMsg0 函 数 是 最 佳 方案 。 
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心 法 领悟 553: ADODB _ ERROR LOG TYPE 常量 设置 错误 记录 的 类 型 。 

用 ADODB_ERROR LOG TYPE 常量 设置 错误 记录 的 类 型 ， 可 选 值 如 下 : 

0: 默认 值 。 根 据 php.ini 文件 中 的 error log 配置 ， 错 误 被 发 送 到 服务 器 日 志 系统 或 文件 。 
1: 错误 被 发 送 到 destination 参数 中 的 地 址 。 只 有 该 类 型 使 用 headers 参数 。 

2: 通过 PHP debugging 连接 来 发 送 错误 。 该 选项 只 在 PHP 3 中 可 用 。 

3: 错误 被 发 送 到 文件 目标 字符 串 。 


加 回回 加 


13.4 ADODB 操作 数据 库 


Eee 一 一 as 
趣味 指教 : 请 请 斌 穴 | 


图 实例 说 明 


虽然 PHP 是 构建 Web 系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函 数 一 直 没有 标准 化 ， 不 同 数据 库 间 的 函数 
名 称 、 参 数 差异 很 大 ， 在 更 换 数据 库 时 ， 会 带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 数 
据 库 函数 间 的 差异 ， 使 开发 者 可 以 很 简单 地 去 切换 数据 库 ， 这 就 是 ADODB 类 库 。 

本 实例 中 ， 应 用 ADODB 访问 Access 数据 库 ， 并 通过 分 页 函数 实现 数据 库 中 数据 的 分 页 输出 ， 其 运行 结果 


如 图 13.19 所 示 。 
nN 亲人 丙 玉英 芒 束 及 着 们 
A 明日 图 书 网 
ne me 


8 再 -页 了 着 


13.19 ADODB 分 页 输出 Access 数据 库 中 的 数据 


力 关键 技术 


应 用 ADODB 操 作 Access 数据库 最 简单 的 方法 就 是 应 用 实例 538 和 实例 539 中 定义 的 ADODB 连接 和 操作 数据 库 类 。 
本 实例 的 目的 是 使 读者 更 深刻 地 理解 ADODB 操作 Access 数据 库 的 方法 和 步骤 。 

(1) 载 入 adodb.inc.php 文件 ， 这 是 应 用 ADODB 类 库 操作 任何 数据 库 的 前 提 。 

(2) 连接 Access 数据 库 服 务 器 ， 依 然 应 用 ADONewConnection0 函 数 ， 但 是 其 参数 值 是 Access。 

(3) 应 用 PConnect0 函 数 连 接 指 定 的 数据 库 文件 。 这 是 Access 数据 库 与 其 他 数据 库 不 同 的 地 方 ， 数据库 文 

件 的 位 置 必须 是 一 个 绝对 路 径 。 

(4) 设置 数据 库 的 编码 格式 。 

ADODB 连接 Access 数据 库 的 关键 代码 如 下 : 


<?php 

include('../adodb$/adodb.inc.php"): // 载 入 (include) adodb.inc.php 文件 

Sconn = ADONewConnection('access’): // 连 接 Access 数据 库 

Sconn-> PConnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=F:\AppServ\www\\imr\13\W017\\data\\db database13.mdb"): 
S$conn -> execute('set names gb2312): /设置 编码 格式 


> 
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图 13.20 所 示 。 


13.20 ADODB 访问 MySQL 数据 库 


图 关键 技术 


在 本 实例 中 ， 应 用 ADONewConnection0 函 数 连接 数据 库 服 务 器 ， 应 用 PConnect0 函 数 连接 db_database13 
数据 库 ， 设 置 用 户 名 为 root， 密 码 为 111， 设 置 数据 库 编码 格式 为 UTF-8。 

通过 execute0 函 数 执行 SQL 语句 ， 在 while 循环 语句 中 ， 应 用 EOF 判断 指针 位 置 ， 应 用 fields 获取 数据 表 
中 对 应 字段 的 值 ， 应 用 MoveNext0 函 数控 制 指针 的 移动 。 

本 实例 中 应 用 的 函数 请 读者 参考 实例 538 和 实例 543 关键 技术 中 的 内 容 ， 这 里 不 再 袭 述 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 创建 index.php 文件 。 首 先 包 含 数据 库 连 接 文件 ， 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 ， 最 后 通过 while 循环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<?php 

include_once (conn/conn phpy): // 载 入 (include) adodb inc php 文件 
$sqlstr = 'select * from tb_beed'; /创建 SQL 语句 

$rst = $conn -> execute($sqlstr) or die(connect error’); /执行 SQL 语句 ， 查 询 出 id 等 于 2 的 数据 
while(!S$rst -> EOF){ /while 语句 循环 输出 结果 

?> 


<b> 
<td height="20" bgcolor="#FFFFFF"><?php echo Srst -> ficlds['id]:?></td> 
<td bgcolor="#FFFFFF"><?php echo S$rst -> fields['name']:?></td> 
<td bgcolor="#FFFFFF"><?php echo S$rst -> fields['type]:?></td> 
<td bgcolor="#FFFFFF"><?php echo Srst -> fields['dates']:?></td> 

< 


<php 
Srst -> MoveNext(): /指针 下 移 
} 
S$rst -> close0: // 关 闭 连接 
$conn -> close0: // 关 闭 数据 库 
> 
力 秘笈 心 法 


心 法 领悟 555: 选择 适合 的 ADODB 操作 数据 库 方法 。 

在 实际 的 Web 程序 开发 过 程 中 , 建议 读者 应 用 实例 538 和 实例 539 中 封装 的 ADODB 连接 和 操作 数据 库 类 
来 实现 对 数据 库 的 操作 。 因 为 这 种 方法 更 适合 对 数据 库 的 管理 、 维 护 和 更 新 ， 一 旦 出 现 更 换 数据 库 服务 器 的 问 
题 也 容易 解决 。 本 实例 中 介绍 的 单一 的 数据 库 连 接 、 操 作 方 法 存在 一 定 的 局 限 性 ， 更 适合 于 读者 在 学 习 阶 段 使 
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用 ， 以 了 解 ADODB 操作 数据 库 的 函数 和 步骤 。 


高 级 | 


实例 556 


力 实例 说 明 


本 实例 介绍 应 用 ADODB 访问 SQL Server 数 据 库 , 并 且 通 过 while 
循环 语句 输出 数据 库 中 的 数据 , 其 中 还 应 用 3ADODB_FETCH_MODE 
变量 控制 结果 集 的 存储 方式 ， 运 行 结 果 如 图 13.21 所 示 。 


| | 关键 技术 图 13.21 ADODB 访问 SQL Server 数据 库 


通过 ADODB 访问 SQL Server 数据 库 的 操作 步骤 与 实例 555 应 用 ADODB 访问 MySQL 数据 库 是 相同 的 ， 
这 里 不 再 歼 述 , 唯一 的 区 别 是 在 访问 SQL Server 数据 库 时 , 应 用 $ADODB FETCH MODE 变量 对 结果 集 的 存 取 
方式 进行 控制 。 

$ADODB_FETCH MODE 变量 决定 结果 集 以 哪 种 方式 进行 存 取 ， 有 关 该 变量 的 详细 讲解 请 参考 实例 544。 

在 通过 ADODB 连接 SQL Server 数据 库 时 还 有 一 点 需要 注意 , 即 在 通过 PConnect() 函 数 连 接 数 据 库 文件 时 ， 
对 Server 服务 器 的 设置 。 如果 SQL Server 数据 库存 储 于 本 机 中 , 那么 Server 的 参数 值 可 以 使 用 localhost。 但 是 ， 
如 果 SQL Server 数据 库存 储 在 其 他 机 器 中 ， 那 么 Server 的 参数 值 必须 是 SQL Server 的 服务 器 名 称 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编写 conn php 文件 ， 完 成 与 SQL Server 数据 库 的 连接 ， 并 且 设置 以 字段 名 称 为 结 
果 集 索引 。 


(2) 编写 index.php 文件 。 首 先 包含 数 据 库 连接 文件 ， 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 ， 最 后 循环 输出 SQL Server 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<2php 

include_once("conn/conn.php"): 

$sqlstr = "select * from tb_goods where addtime="2009-5-23" "; // 创 建 SQL 语句 

Srst = $conn -> execute($sqlstr) or die(connect error’); /| 执行 SQL 

while(!$rst -> EOF){ // 如 果 没 有 错误 ， 则 配合 while 循环 输出 结果 
?> 


<t> 
<td align="left" bgcolor="#FFFFFF">&nbsp:<?php echo iconv('gb2312',"utf-8",Srst -> ficlds['name']):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $rst -> ficlds['addtime']:?></td> 
<td align="left" bgcolor="#FFFFFF">&nbsp:<?php echo $rst -> ficlds['counts]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $rst -> ficlds['price]:?></td> 

</t> 


Srst -> movenext(): /1/ 指 针 下 移 
Srst -> close0; // 关 闭 连接 


?> 


力 秘笈 心 法 


心 法 领悟 556: 了 解 ADODB 操作 数据 库 的 方法 和 步骤 。 

在 本 节 的 3 个 实例 中 ， 分 别 介绍 了 如 何 通过 ADODB 操作 Access、MySQL 和 SQL Server 数据 库 ， 其 目的 
是 让 读者 对 ADODB 中 操作 数据 库 的 方法 和 步骤 有 一 个 系统 的 了 解 ， 从 中 读者 可 以 体会 到 ， 无 论 是 操作 哪 种 数 
据 库 ， 所 使 用 的 方法 和 操作 步骤 基本 都 是 相同 的 ， 这 就 是 ADODB 类 库 的 强大 之 处 ， 这 也 就 是 笔者 建议 在 实际 
的 程序 开发 过 程 中 使 用 实例 538 和 实例 539 中 封装 的 类 来 连接 和 操作 数据 库 的 原因 。 
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力 实例 说 明 

PHP 没有 内 置 Smarty 模板 类 ， 需 要 单独 下 载 和 配置 ， 并 且 Smarty 要 求 服务 器 上 的 PHP 版 本 最 低 为 4.0.6。 
用 户 可 以 去 网 站 http://www.smarty.net/download.php 下 载 最 新 的 Smarty 压缩 包 。 本 书 使 用 的 版 本 是 Smarty 2.6.23， 
下 载 页面 如 图 14.1 所 示 。 
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图 14.1 Smarty 模板 下 载 页 面 
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Smarty 模块 的 安装 步骤 : 
(1) 将 下 载 的 Smarty 压缩 包 解压 ,解压 后 的 文件 夹 如 图 14.2 所 示 , 其 中 有 一 个 libs 文件 夹 , 它 包含 了 Smarty 
类 库 的 4 个 核心 文件 : Smarty.class.php、Smarty_Compiler.class.php、Config_File.class.php 和 debug.tpl, 以 及 internals 
和 plugins 两 个 文件 夹 ， 如 图 14.3 所 示 。 
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图 14.3 ”Smarty-2.6.23 的 libs 文件 
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件 。 这 4 个 文件 夹具 体 放置 在 什么 位 置 没有 严格 的 规定 ， 只 要 设置 路 径 正 确 即 可 。 在 本 实例 中 ， 将 创建 的 4 个 
文件 夹 存储 在 558\Smarty 文件 夹 下 。 
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图 14.6 第 一 个 Smarty 程序 


(3) 创建 配置 文件 。 如 果 要 应 用 Smarty 模板 ， 那 么 就 一 定 要 包含 Smarty 类 库 和 相关 信息 。 配 置信 息 可 以 
存储 在 一 个 单独 的 文件 中 ， 在 需要 时 通过 include 语句 包含 即 可 。 配 置 文件 config.php 的 代码 如 下 : 


<2pl 
人 # ”定义 服务 器 的 绝对 路 径 。*/ 
define(BASE_ PATH',$_SERVER[DOCUMENT_ROOT]): 
上 # 定义 Smarty 模板 的 绝对 路 径 */ 
define('SMARTY_PATH'\mn\14\Smarty\); 
请 加载 Smarty 类 库 文件 。*/ 
require BASE_PATH.SMARTY_PATH.'Smarty.class.php'; 
上 # 实例 化 一 个 Smarty 对 象 */ 
$smarty = new Smarty: 

族 定义 各 个 目录 的 路 径 。 村 


$smarty->template_dir 一 ' /定义 模板 文件 的 存储 位 置 
Ssmarty->compile /Smarty/templates_c/'; // 定 义 编译 文件 的 存储 位 置 
S$smarty->config marty/configs/"; // 定 义 配置 文件 的 存储 位 置 
$smarty->cache_dir ="/Smarty/cache/"; // 定 义 缓存 文件 的 存储 位 置 


> 
图 设计 过 程 
完成 Smarty 模板 的 配置 后 ， 编 写 一 个 实例 ， 体 会 Smarty 模板 引擎 的 特性 。 

(1) 在 实例 558 文件 夹 下 创建 index.php 文件 ， 编 写 动态 PHP 代码 。 首 先 设置 页 面 的 编码 格式 ， 然 后 通过 
include 语句 包含 Smarty 的 配置 文件 ， 最 后 通过 Smarty 类 库 中 的 assign() 方 法 将 数据 赋 给 模板 变量 ， 并 且 应 用 
display 指定 模板 页 ， 其 代码 如 下 : 

< 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 页 面 编码 格式 
include("config.php"): // 包 含 配 置 文 件 


店 使 用 Smarty 赋值 方法 将 一 对 名 称 /方法 发 送 到 模板 中 。*/ 
$smarty->assign('title', 第 一 个 Smarty 程序 ); 


$str = file_get_contents('files/content.txt’): // 读 取 文本 文件 中 的 数据 
$smarty->assign('content iconv("gb2312","utf-8",$str)): // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
店 显示 模板 */ 

Ssmarty->display(index html'); 

> 


回 ”assign() 方 法 用 于 在 模板 被 执行 时 为 模板 变量 赋值 ， 语 法 如 下 : 


{assign var=" " value=" "} 
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Warning require(E- AppServ www mrs 14 Smarty Smarty class php) 
[function require]:failed to open stream No such fle or directory n 
E:\AppServ\wwiMR\14\558\config php on ine 7 


Fatal error requireO [finction require] Failed opening required 
‘EAppServiwwwmrs 14\Smarty' Smarty class php' (inciude_path=" ;Cphp5 
‘pear) in E:\AppServiwwiMR\14\558\config.php on line 7 
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图 14.7 找 不 到 指定 的 Smarty 类 库 文件 


本 实例 向 读者 介绍 另外 一 种 Smarty 模板 的 配置 方法 ， 使 用 这 种 方法 ,无 论 怎么 改变 实例 的 文件 夹 ， 都 不 会 
影响 实例 的 运行 。 


图 关键 技术 


这 里 将 Smarty 配置 方法 封装 到 类 中 ， 并 存储 到 system.smarty.inc.php 文件 中 。 首 先 包含 Smarty 类 文件 
Smarty.class.php， 然 后 定义 SmartyProject 类 ， 继 承 Smarty 父 类 ， 最 后 定义 SmartyProject0 方 法 ， 设 置 Smarty 中 
模板 文件 〈templates) 、 编 译文 件 〈templates c) 、 配 置 文 件 (configs〉 和 缓存 文件 (cache〉 的 存储 位 置 。 这 
就 是 新 的 配置 文件 system.smarty.ine.php， 其 代码 如 下 : 


<?php 
require("../Smarty/Smarty.class.php"); /调用 Smarty 文件 
class SmartyProject extends Smartyf // 定 义 类 ， 继 承 Smarty 父 类 
i /定义 方法 ， 配 置 Smarty 模板 
/指定 模板 文件 存储 在 根 目录 下 
ws es el; // 指 定编 译文 件 存储 位 置 


Sthis->config_dir = ="./system/Smarty/configs/"; 
Sthis->cache_dir ="./system/Smarty/cache/": 
} 
} 
了 


既然 已 经 将 Smarty 的 配置 方法 存储 到 一 个 类 中 ， 那 么 就 需要 对 类 进行 实例 化 ， 根 据 返回 的 对 象 名 称 调用 
Smarty 中 的 方法 ， 类 的 实例 化 操作 在 system.inc.php 文件 中 完成 ， 其 返回 对 象 名 为 $smarty， 其 代码 如 下 : 


<?php 
require("system.smarty.inc.php"); // 调 用 类 文件 
$smarty=new SmartyProject(); /执行 类 的 实例 化 操作 


?> 


通过 此 方法 配置 Smarty 模板 的 好 处 是 ， 无 论 将 程序 复制 到 哪个 服务 器 下 执行 ， 都 不 需要 更 改 服务 器 或 者 
Smarty 文件 的 绝对 路 径 ， 程 序 可 以 直接 运行 。 


.BY 技巧 : 这 种 配置 方法 中 调用 的 仍 是 存储 在 章 文件 央 14 下 的 Smarty 类 库 ， 同 时 在 这 种 方法 中 将 配置 文件 存 
储 于 实例 根 目 录 下 的 system 文件 天 中 ， 将 模板 文件 夹 〈templates) 、 编 译文 件 央 templates_c) 、 
配置 文件 天 (configs) 和 缓存 文件 夹 《cache) 存储 在 system\Smarty 目录 下 。 


图 设计 过 程 
下 面 应 用 新 的 配置 方法 对 实例 558 进行 重新 编写 ， 生 成 实例 559， 步 又 如 下 : 
(1) 在 实例 的 根 目 录 下 创建 system 文件 夹 , 存储 Smarty 的 配置 文件 system.smarty.incphp 和 实例 化 操作 文 
件 system.inc.php, 同时 创建 Smarty 文件 夹 ,最 后 在 Smarty 文件 夹 下 创建 3 个 文件 夹 templates_c、configs 和 cache。 


(2) 编写 index.php 文件 ， 重 新 载 入 Smarty 的 配置 文件 ， 即 通过 include 语句 包含 system.inc.php。 
(3) 其 他 内 容 与 实例 558 相同 ， 这 里 不 再 袭 述 。 
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图 关键 技术 


在 模板 页 中 判断 用 户 访问 权限 的 关键 是 让 语句 和 模板 变量 的 结合 运用 。 在 让 语句 中 ， 判 断 模板 变量 的 值 是 
否 为 T， 如 果 为 T， 则 说 明 具 备 访问 权限 ; 如果 模板 变量 值 为 F， 则 说 明 不 具备 访问 权限 。 

Smarty 模板 中 的 让 与 PHP 中 的 站 大 同 小 异 。 需要 注意 的 一 点 是 ，Smarty 模板 中 的 让 必 须 以 /让 为 结束 标记 ， 
其 语法 格式 如 下 : 

全 条 件 语句 匡 


语句 1 
{elscif 条 件 语句 2} 


模板 变量 的 定义 应 用 assign0 方 法 ， 在 PHP 动态 页 中 根据 用 户 权 限 的 判断 结果 为 模板 变量 赋值 。 
图 设计 过 程 


(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 创 建 存储 编译 文件 、 缓 存 文件 和 配置 文件 的 文件 
夹 。 其 具体 内 容 可 以 参考 实例 559， 这 里 不 再 袭 述 。 

(2) 创建 index.php 文件 ， 包 含 Smarty 配置 文件 ， 指 定 Smarty 的 模板 页 index.html。 

(3) 创建 Smarty 模板 页 index.html， 设 计 用 户 登录 页 面 ， 添 加 用 户 登 录 的 表单 元 素 ， 并 且 将 用 户 的 登录 信 
息 提交 到 index_ok.php 文件 。 

(4) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 判 断 提 交 的 用 户 名 和 密码 是 否 正 确 ， 如 果 正 确 则 通 
过 display0 方 法 指定 模板 页 main.html， 并且 为 模板 变量 competence 赋值 为 T; 否则 指定 到 模板 页 main html， 为 
模板 变量 competence 赋值 为 F， 其 关键 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 1/ 设置 文件 编码 格式 
include("system/system.ine.php"): // 包 含 配 置 文件 


if($_POST['Submit]!="" && $_POST['user]!="" && $ orl "){ 
if($_POST['user]—"mr" && $_ POST[pass] 一 "mrsoft){ 
Ssmarty->assign("competence","T"); /为 模板 变量 赋值 
$smarty->display(main html)): 1/ 指定 模板 页 
jelse{ 
S$smarty->assign("competence","F"); 
Ssmarty->display('main.html'); 
} 
jelse{ 
echo "<script>alert( 用 户 名 和 密码 不 能 为 空 ! ); window.location href='index.php':</script>"; 


?> 
(5) 创建 main.html 模板 页 。 首 先 应 用 站 语句 对 模板 变量 的 值 进行 判断 ， 如 果 值 为 则 输出 本 页 内 容 ， 如 


果 值 为 F 则 给 出 提示 信息 ， 其 关键 代码 如 下 : 
{if $competence—"T"} 
/省 略 了 部 分 内 容 
{8 
{if Scompetence—"F"} 
<script>alert( 您 没有 权限 访问 ， 请 重新 登录 ):window ,location href="index php":</script> 
{ 刘 


力 秘笈 心 法 
心 法 领悟 560: Smarty 模板 中 让 条 件 语句 的 修饰 词 。 
Smarty 模板 中 让 条 件 语句 ， 除 了 可 以 使 用 PHP 中 的 <、>、=、!= 等 常见 运算 符 外 ,还 可 以 使 用 eq、 ne、 neq、 


gt, lt, lte、 le、gte、ge、iseven、is odd、is not even、is not odd、not、mod、div by、even by、odd by 等 修饰 词 
修饰 。 
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力 实例 说 明 


本 实例 应 用 Smarty 模板 中 的 foreach 语句 在 模板 页 中 直接 生成 一 个 数字 验证 码 ， 它 相当 于 在 动态 PHP 中 开 
发 的 验证 码 ， 但 更 加 简单 、 实 用 。Smarty 模板 中 生成 验证 码 的 运行 结果 如 图 14.10 所 示 。 


用 户 名 ; 后 一 一 验证 权 : 371999 
二 三 : owes BE ss 


图 14.10 ”Smarty 模板 中 生成 数字 验证 码 


图 关键 技术 


严格 地 说 ， 这 个 验证 码 不 是 在 Smarty 模板 页 中 生成 的 ， 只 是 通过 foreach 语句 将 PHP 动态 页 中 生成 的 验证 
码 在 模板 页 中 输出 。 因 此 本 实例 开发 的 关键 是 foreach 语句 的 应 用 和 验证 码 的 生成 。 
(1) 应 用 mt_rand0 函 数 生成 验证 码 ， 其 语法 如 下 : 
int mt_rand ( [int min, int max]) 
如 果 mt_rand0 函 数 没有 提供 可 选 参数 min 和 max， 则 返回 0~RAND_MAX 之 间 的 伪 随 机 数 。 
(2) 应 用 explode0) 函 数 将 生成 的 验证 码 写 入 数组 中 ， 其 语法 如 下 : 
array explode(string separator, string string, [int limit]) 
返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子 串 ， 它 们 被 字符 串 separator 作为 边界 点 分 隔 出 来 。 
如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 。 
如 果 separator 为 空 字符 串 〈"") ，explode0 函 数 将 返回 FALSE; 如 果 separator 所 包含 的 值 在 string 中 找 不 
到 ， 那 么 explode0 函 数 将 返回 包含 string 单个 元 素 的 数组 ， 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 
元 素 外 的 所 有 元 素 。 
(3) 通过 assign0 方 法 将 验证 码 数 组 赋 给 模板 变量 。 
il foreach 语句 循环 输出 模板 变量 中 的 数组 元 素 。foreach 的 语法 如 下 : 


1 name key=key item=item from=arr name} 
ey 


参数 name 为 该 循环 的 名 称 ，key 为 当前 元 素 的 键 值 ，item 是 当前 元 素 的 变量 名 ; from 是 该 循环 的 数组 。 其 
中 ，item 和 from 是 必 选 参数 ， 不 可 省 略 。 


力 设计 过 程 
(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 著述 。 


a 
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(2) 创建 index.php 文件 ， 生 成 验证 码 并 且 将 验证 码 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 
<?php 


require_once("system/system ine.php"); // 包 含 配置 文件 

Sarray= explode( ', mt_rand(1000.9999)); /1/ 生 成 随机 验证 码 
$smarty->assign('title'"Smarty 模板 中 生成 数字 验证 码 ): // 将 指定 数据 赋 给 模板 变量 
Ssmarty->assign('content' Sarray): // 将 数组 赋 给 模板 变量 
$smarty->display(index-html); /指定 模板 页 

> 


(3) 创建 index.html 模板 文件 ， 设 计 用 户 登录 页 面 ， 添 加 用 户 登 录 的 表单 元 素 ， 同 时 应 用 foreach 语句 输 
出 模板 变量 中 传递 的 验证 码 ， 其 关键 代码 如 下 : 


<form id="forml" name="forml" method="post" action="index ok.php"> 
<input name="user" type="text" id="user" size="10" /> 
<input type="hidden" name="checks" value="{foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" size="8" /> 
<input name="pass" type="password" id="pass" size="10" /> 
<input type="image" name="imageField" src="images/Blog 03_03.jpg" /> 
<input type="image" name="imageField2" onclick="form.resetO):return false:" sre="images/Blog_03_06.jpg" /> 

</form> 

(4) 创建 index_ok.php 文件 ,获取 表单 中 提交 的 数据 , 对 用 户 登录 信息 进行 验证 。 如 果 用 户 名 和 密码 正确 ， 
则 跳 转 到 main.php 页 面 ， 否 则 跳 转 到 index.php 页 面 。 


(5) 创建 main.php 和 main.html 文件 作为 网 站 的 主页 。 
国 秘笈 心 法 


心 法 领悟 561: 验证 码 的 运用 。 
本 实例 中 ， 应 用 foreach 语句 输出 验证 码 ， 如 果 要 更 新 验证 码 的 值 ， 可 以 单 击 “ 刷 新 ”按钮 或 者 按 F5 键 ， 
同样 也 可 以 在 地 址 栏 中 重新 输入 地 址 。 


实例 562 趣味 指教 : 请 请 请 家 
实例 说 明 


在 Smarty 模板 页 中 ， 同 样 可 以 将 网 页 的 头 、 尾 和 主 文件 分 别 进行 存储 ， 从 而 达到 页 面 重 用 的 效果 ， 这 就 是 
本 实例 将 要 讲解 的 内 容 一 一 在 Smarty 模板 页 中 设计 网 页 页 面 ， 其 运行 结果 如 图 14.11 所 示 。 


FANXING mans wr ,wen /am 
hem "chesw 雪人 如 片 妆 件 天 
口 。 村 呈 玄 团 放 关外 uo 32330 = = 
更 各 联系 方式 
口 。 棚 二 站 时 让 二 外 uo 33s0 多 UN 和 
口 。 栋 题 位置 放生 处 mio 3330 = 
更 名 电子 图书 
口 。 大 eme 外 to a330 us nm 
口 。 标题 玄 轩 放 于 处 ti 2220 
口 。 标题 玄 村 放生 外 au aoa0 
口 。 机 要 位 叶 放 理 处 am aaa0 
口 。 杞 评委 放生 外 mo 3330 
共有 2 页 ， 当 商 是 第 1 页 PE FRI) 


图 14.11 Smarty 模板 中 的 页 面 设 计 
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力 关键 技术 


在 Smarty 模板 页 中 应 用 include 函数 载 入 模板 页 。include 函数 用 于 在 当前 模板 中 包含 其 他 模板 ， 当 前 模板 
中 的 变量 在 被 包含 的 模板 中 可 用 。include 函数 的 语法 如 下 : 


{include file="file name " assign=" " var=" "} 
参数 file 指定 包含 模板 文件 的 名 称 ， 为 必 选 参数 ， 参 数 assign 指定 一 个 变量 保存 包含 模板 的 输出 ;参数 var 
传递 待 包含 模板 的 本 地 参数 ， 只 在 待 包含 模板 中 有 效 。 


图 设计 过 程 
(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 歼 述 。 


(2) 创建 index.php 文件 ， 应 用 switch 语句 根据 超 链接 传递 的 变量 值 ， 包 含 不 同 的 PHP 脚本 文件 ， 同 时 将 
对 应 的 模板 页 名 称 赋 给 指定 的 模板 变量 ， 其 代码 如 下 : 


<?php 


require("system/system_inc.php"); // 载 入 配置 文件 
switch ($_GET['caption']){ /应 用 switeh 语句 进行 判断 
Case "reg": 
include "reg.php"; // 包 含 PHP 脚本 
$smarty->assign('admin_phtml',reg.html); // 通 过 模板 变量 指定 模板 页 
break: 
case "log": 
include "log.php"; 


Ssmarty->assign(admin_phtml',log html’); 
break; 


case "from": 
include "for.php"; 
Ssmarty->assign('admin_phtml',for.html); 
break; 


case "mes": 
include "mes.php"; 
Ssmarty->assign('admin_phtml',‘mes.html’); 
break; 


default: 
include "for.php"; 
$smarty->assign('admin_phtml',for.html); 
break: 


} 

$smarty->assign("title","Smarty 模板 中 的 页 面 设计 --".$_GET[caption]); 
S$smarty->display("index.html"); // 指 定 模板 页 
?> 


(3) 创建 index.html 模板 页 ， 应 用 include 函数 载 入 页 面 的 头 文件 〈top.html) 、 尾 文件 〈bottom.html) 和 


主 文件 ， 其 关键 代码 如 下 : 
{Stite} 
{inelude file=top html} 
{include file=$admin phtml} 
{include file=right html} 
{include file=bottom html} 


(4) 创建 include 函数 加 载 的 模板 文件 和 动态 PHP 文件 。 
图 秘笈 心 法 
心 法 领悟 562: switch 语句 的 应 用 。 
在 程序 设计 中 ， 所 有 依据 条 件 做 出 判定 的 问题 ， 都 可 以 用 让 条 件 语句 来 解决 。 不 过 ， 在 用 让 .else… 语 句 处 


理 多 个 条 件 的 判定 问题 时 ， 组 成 条 件 的 表达 式 在 每 一 个 elseif 中 都 要 计算 一 次 ， 比 较 繁琐 。 为 了 避免 计 语句 的 
宛 长 ， 提 高 程序 的 可 读 性 ， 可 以 使 用 switch 分 支 控制 语句 。switch 语句 的 语法 如 下 : 


switch(variablej{ 

case valuel: 
statement]: 
break: 


PHP 开发 实例 大 全 (基础 卷 ) 
case value2: 


default: 
default statement n: 


} 

switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比较 ， 如 果 不 相 等 ， 继 续 查 找 下 一 个 case; 如 果 
相等 ,就 执行 对 应 的 语句 ,直到 switch 语句 结束 或 遇 到 break 为止, 一般 switch 语句 的 最 后 都 有 一 个 默认 值 default， 
如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 ， 和 else 语句 类 似 。 


力 实例 说 明 


由 于 在 Smarty 模板 中 默认 使 用 “{” 和 “}” 作 
为 定 界 符 ， 所 以 如 果 直 接 在 Smarty 模板 中 定义 CSS 六 三 [6]htts: 1/192 168.1.53/or/14/007/ 可 上 日 亲 
样式 ， 将 输出 如 图 14.12 所 示 的 错误 。 ee Smarty error [in indax.htmlline 8]: syntax i 

该 错误 出 现 的 原因 是 在 Smarty 模板 页 中 直接 将 。 | seesgieec we ei Rew Goa Copier ee Pip bas 
CSS 样式 中 使 用 的 “{” 和 “}” 解 析 为 Smarty 模板 届 辣 ne = 
的 定 界 符 ， 为 了 避免 在 Smarty 模板 中 直接 定义 CSS 。 S 
样式 时 出 现 错误 ，Smarty 提供 了 特殊 的 处 理 方法 ， 14.12 在 Smarty 模板 中 直接 定义 CSS 样式 时 出 现 的 错误 
这 就 是 本 实例 将 要 讲解 的 literal 标签 。 


图 关键 技术 


literal 标签 将 区 域内 的 数据 当 作文 本 处 理 ， 此 时 模板 将 忽略 其 内 部 的 所 有 字符 信息 。 该 特性 用 于 显示 有 可 
能 包含 大 括号 等 字符 信息 的 CSS 样式 或 者 JavaScript 脚本 ， 当 这 些 信 息 处 于 {literal} {/literal} 标签 中 时 ， 模 板 
引擎 将 不 进行 分 析 而 直接 显示 。 
图 设计 过 程 

这 里 仍然 应 用 实例 561 中 的 内 容 ， 唯 一 的 区 别 是 在 index.html 模板 页 中 ， 通 过 {literal} Uliteral} 标签 定义 一 
个 CSS 样式 ， 控 制 页 面 中 表格 、 文 字 的 背景 、 字 体 和 大 小 等 ， 其 关键 代码 如 下 : 

人 

< 一 


body,td,th { 
font-size: 12px: 


高 级 | 
起 味 指数 : 庚 负 去 家 ， 


文件 刀 铺 辑 如 查看 WW 收 康 ) 工具 CD) 和 助 WD 


I 2 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 基础 着) 
图 设计 过 程 


这 里 仍然 应 用 实例 561 中 的 内 容 ， 唯 一 的 区 别 是 在 index.html 模板 页 中 ,直接 定义 JavaScript 脚本 对 表单 中 
提交 的 数据 进行 判断 ， 通 过 ldelim 和 rdelim 标签 在 Smarty 模板 中 输出 “{” 和 “}”， 其 关键 代码 如 下 : 


<script language=iavascript> 


{rdelim} 
if (form.check.value =— "){ldelim} 
alert(' 请 输入 验证 码 ): 


本 实例 中 的 其 他 内 容 这 里 不 再 歼 述 ， 其 完整 代码 请 参考 本 书 光盘 。 
国 秘笈 心 ; 
心 法 领悟 564: literal 标签 与 ltelim、rdelim 标签 的 比较 。 
literal 标签 将 “{” 与 “}” 之 间 的 内 容 按 普通 的 文本 文件 来 解析 ， 控 制 的 是 内 容 ， 而 ldelim 与 rdelim 标签 


在 Smarty 模板 中 输出 “{” 与 “}”， 是 对 大 括号 本 身 进行 操作 。 在 Smarty 模板 中 完成 CSS 样式 或 者 JavaScript 
脚本 的 嵌入 操作 时 ， 笔 者 个 人 认为 还 是 使 用 literal 标签 方便 一 些 。 


趣味 指数 ; 请 良 育 家 
实例 说 明 


在 开发 程序 的 过 程 中 ， 经 常用 到 下 拉 列 表 框 ， 可 以 直接 
在 页 面 中 为 其 定义 值 ， 也 可 以 使 用 从 数据 库 中 读 取 的 数据 来 
定义 ， 但 无 论 使 用 哪 种 方法 都 必须 应 用 option 标签 ， 这 是 在 
常规 的 Web 页 面 中 为 下 拉 列 表 框 赋值 的 方法 。 

本 实例 将 介绍 通过 Smarty 模板 中 的 自 定义 函数 html_ 
options 为 下 拉 列 表 框 赋值 。 使 用 Smarty 模板 中 的 自 定义 函数 
为 下 拉 列 表 框 赋值 与 使 用 option 标签 实现 的 效果 是 相同 的 ， 
但 是 这 种 方法 更 适合 从 数据 库 中 读 取 数 据 ， 更 符合 Smarty 开 
发 模式 动静 分 离 的 原则 ， 运 行 结果 如 图 14.14 所 示 。 


图 关键 技术 


自 定义 函数 html_options 根据 给 定 的 数据 创建 选项 组 .该 RN = 
函数 可 以 指定 哪些 元 素 被 选 定 ， 要 么 指定 values 和 ouput 属 
性 ， 要 么 指定 options 替代 。 自 定义 函数 的 语法 如 下 : 


wy 


| 


图 14.14 通过 html_options 函数 为 下 拉 列 表 框 赋值 
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<select name=customer id> 


{html_options values=$cust_ids selected=$customer id output=$cust_names} 
</select> 


html_options 函数 的 参数 说 明 如 表 14.1 所 示 。 
表 14.1 html_options 函数 的 参数 说 明 
类 型 


参数 说 明 


name | string 下 拉 菜 单 名 称 ， 默 认 值 为 空 
options | associative array 包含 值 和 显示 的 关联 数组 

selected | string/array, 已 选 定 的 元 素 或 元 素数 组 

output | array 包含 下 拉 列 表 各 元 素 显示 值 的 数组 


Values arTS 包含 下 拉 列 表 各 元 素 值 的 数组 


如 果 给 定 值 是 数组 ， 将 作为 OPTGROUP 处 理 ， 且 支持 递归 。 所 有 的 输出 与 XHTML 兼容 。 

如 果 指 定 可 选 属性 name， 该 选项 列表 将 被 置 于 <select name="groupname"></selec 人 > 标签 中 ， 如 果 没 有 指定 ， 
只 产生 选项 列表 。 
图 设计 过 程 

(1) 创建 system 文件 夹 。 首 先 定义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 以 及 ADODB 连接 
和 操作 数据 库 的 方法 。 然 后 定义 system.inc.php 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 实例 化 ， 并 
返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 index.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 生成 随机 验证 码 ， 并 且 将 随机 
验证 码 的 值 赋 给 模板 变量 。 接 着 从 数据 库 中 读 取 数据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模板 变量 ， 
作为 下 拉 列 表 框 中 的 值 。 最 后 指定 模板 页 ， 其 代码 如 下 : 


<?php 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("systenm/system.inc.php"); // 包 含 配 置 文 件 

S$array= explode(' ', mt_rand(1000,9999)): // 生 成 随机 验证 码 
$smarty->assign('title','html_option 函数 向 下 拉 列 表 中 添加 列表 项 ); // 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', Sarray); // 将 数组 赋 给 模板 变量 
S$res=$conn->execute("select + from tb_bced "): /执行 select 查询 语句 
Sarray=$res->GetArray(); // 返 回 查询 结果 
Sarray_id=array(); 


Sarray_name=array(): 
for($i=0:$i<$res->RecordCountO:Si+t){ 
Sarray_id[]=$array[$i][id]: 

Sarray_name[]=$array[$i][name]: 


} 
S$smarty->assign('cust_id', $array_id); // 设 置 下 拉 列 表 框 的 值 


S$smarty->assign('cust_name', $array_name): // 设 置 列表 框 的 显示 数据 
$smarty->display(index.html): /指定 模板 页 


> 

(3) 创建 index.html 模板 页 。 首 先 创建 form 表单 ， 添 加 表单 元 素 ， 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html_options 自 定义 函数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 。 然 后 应 
用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 ， 对 用 户 提交 的 信息 进行 验证 ， 其 关键 代码 如 下 : 


<form id="form" name="form" method="post" action="index_ok.php" onsubmit="return check_form(); "> 
词典 选择 :<select name="customer" id="customer"> {html_options output=$cust_name values=$cust_id }</select> 
验证 码 : <input type="hidden" id="checks" name="checks" value="{foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content} {$item} {/foreach} 
<input type="image" name="imageField3" sre="images/reg_07.jpg" /> 
<input type="image" name="imageFicld4" onclick="form.reset():return false:" sre="images/reg_09.jpg" /> 
</form> 

(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 将 数据 添加 到 数据 表 中 ， 其 代码 如 下 : 
<Iphp 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


图 关键 技术 
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在 Smarty 模板 中 ， 通 过 自 定义 函数 html select date 和 html select time 生成 日 期 、 时 间 选 择 器 。 
html select_date 函数 用 于 创建 日 期 下 拉 菜 单 ， 可 以 显示 任意 年 、 月 、 日 。html select_date 函数 的 语法 说 明 


如 表 14.2 所 示 。 
表 14.2 html_select_date 函数 的 语法 说 明 
属 性 类 型 是 否 必需 的 | 默 认 值 说 明 
year size 如 果 设 置 ， 为 标签 添加 大 小 属性 
all_extra string No null 如 果 设 置 ， 为 所 有 标签 添加 附加 属性 
day_extra 如 果 设 置 ， 为 标签 添加 附加 属性 
month extra 如 果 设 置 ， 为 标签 添加 附加 属性 
year extra 如 果 设 置 ， 为 标签 添加 附加 属性 
field_order 显示 区 域 的 顺序 
field_separator 各 区 域 间 输出 的 分 隔 字符 串 


Imonth value_format 


year Size 


月 份 值 的 strftime 表示 方法 ， 默 认为 %m 
如 果 设 置 ， 为 标签 添加 大 小 属性 


html select_time 函数 用 于 创建 时 间 下 拉 菜单 ， 可 以 显示 任意 时 、 分 、 秒 。html_ select time 函数 的 语法 说 明 


如 表 14.3 所 示 。 


表 14.3 html_select_time 函数 的 语法 说 明 


属 性 类 型 说 了 明 
prefix string 变量 名 称 前 级 
time timestamp 使 用 时 间 类 型 (data/time) 
display hours boolean 是 否 显示 小 时 
display minutes boolean 是 否 显示 分 钟 
display_seconds boolean 是 否 显示 秒 
display_meridian boolean 是 否 显示 正午 界 〈 上 午 / 下 午 ) 
use_ 24 hours boolean 是 否 使 用 24 小 时 制 
minute_interval integer 分 钟 下 拉 列 表 框 的 间隔 
Second interval integer 秒 钟 下 拉 列 表 框 的 间隔 
field array string 输出 值 到 该 值 指定 的 数组 
all extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
hour extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
minute_extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
second extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
meridian extra string 如 果 设 置 ， 为 标签 添加 附加 属性 


国 设计 过 程 


(1) 创建 system 文件 夹 。 首 先 定义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 以 及 ADODB 连 
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14.3 综合 应 用 


Eee 


趣味 指数 : 二 页 丰 容 | 


实例 567 


力 实例 说 明 


在 本 实例 中 ,综合 运用 前 面 讲解 的 方法 、 技 术 , 在 模板 页 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 , 通过 foreach 
语句 输出 验证 码 ， 通 过 html_options 函数 定义 下 拉 列 表 框 的 值 ， 并 且 增加 AJAX 技术 实现 用 户 名 的 无 刷新 验证 ， 
开发 一 个 完整 的 Smarty 用 户 注册 功能 模块 其 ; 运行 结果 如 图 14.17 所 示 。 


图 14.17 Smarty 模板 中 的 用 户 注册 


图 关键 技术 


通过 AJAX 技术 实现 无 刷新 验证 整体 上 可 以 分 为 3 个 步 又 : 
(1) 在 模板 页 中 ， 通 过 script 标签 调用 指定 的 JS 文件 。 创 建 form 表单 ， 添 加 表单 元 素 ， 通 过 onBlur 事件 
调用 JavaScript 脚本 函数 ， 完 成 对 表单 元 素 值 的 判断 。 
(2) 编写 JavaScript 脚本 文件 ， 创 建 自 定义 函数 ， 应 用 AJAX 技术 完成 对 表单 元 素 值 的 验证 。 
(3) 在 模板 页 中 ， 通 过 <div> 标 签 输出 验证 结果 。 
其 中 应 用 到 的 AJAX 技术 如 下 : 
(1) 在 使 用 XMLHttpRequest 对 象 发 送 请 求 和 处 理 响 应 之 前 首先 需要 初始 化 该 对 象 , 由 于 XMLHttpRequest 
不 是 一 个 W3C 标准 ， 所 以 对 于 不 同 的 浏览 器 ， 初 始 化 的 方法 也 是 不 同 的 。 


这 里 使 用 正 浏览 器 把 XMLHttpRequest 个 ActiveX 对 象 ， 具 体 方法 如 下 : 

var http_request = new ActiveXObject("Msxml2 .XMLHTTP"): 

或 者 

var http_request = new ActiveXObject("Microsoft XMLHTTP"): 

在 上 面 的 语法 中 ，Msxml2.XMLHTTP 和 MicrosoftXMLHTTP 是 针对 正 浏览 器 的 不 同 版 本 而 进行 设置 的 。 
(2) open0 方 法 。open0 方 法 用 于 设置 进行 异步 请 求 目 标的 URL、 请 求 方法 以 及 其 他 参数 信息 ， 语 法 如 下 : 

open("method","URL"[.asyncFlag{."userName"[. "password"]]]) 

在 上 面 的 语法 中 ，method 用 于 指定 请 求 的 类 型 ， 一 般 为 GET 或 POST; URL 用 于 指定 请 求 地 址 ,可 以 使 用 
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@ 发 送 HTTP 请 求 ， 语 法 格式 如 下 : 

xmilobj.open(send_method,url,flag): 

其 中 xmlobj 是 XMLHttpRequest 的 对 象 ，send_method 是 发 送 方 法 ， 可 以 是 GET 或 者 POST， 与 表单 中 使 
用 的 方法 相对 应 ;url 是 页 面 要 调用 的 地 址 ; fag 是 一 个 标记 ， 如 果 为 TRUE 则 表示 在 等 待 被 调用 页 面 响应 的 时 
间 内 可 以 继续 执行 页 面 代码 ， 反 之 为 FALSE。 
图 设计 过 程 

(1) 定义 Smarty 的 配置 方法 和 ADODB 连接 、 操 作 数 据 库 的 方法 ， 有 关内 容 请 参考 实例 565， 这 里 不 再 
赣 述 。 

(2) 创建 index.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 ， 然 后 生成 随机 验证 码 ， 并 且 将 随机 
验证 码 的 值 赋 给 模板 变量 ， 接 着 从 数据 库 中 读 取 数据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模板 变量 ， 
作为 下 拉 列 表 框 中 的 值 ， 最 后 指定 模板 页 。 

(3) 创建 index.html 模板 页 。 首 先 创建 form 表单 ， 添 加 表单 元 素 ， 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html options 自 定义 函数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 ， 然 后 应 
用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 ， 最 后 通过 script 标签 载 入 JavaScript 脚本 文件 ， 对 用 户 提交 的 注册 信 
息 进行 判断 ， 其 关键 代码 如 下 : 


{literal} 

<style type="text/css"> 

body,td,th { 

font-size: 12px; 

} 

</style> 

{/literal} 

‘<script language="javascript" src="js/createxmlhttp.js"></script> 

<script language="javascript" sre="js/check_form-js"></script> 

<form id="form" name="form" method="post" action="index._ok.php" onsubmit="retun check_form(): "> 

用 户 名 :<input name="user" type="text" id="user" onBlur="javascript:chkname()" size="20" /> 

<div id="user_check"><font color="#999999"> 请 输入 用 户 名 </font></div> 

词典 选择 <select name="customer" id="customer"> {html_options output=$cust_name values=$cust_id }</select> 

验证 码 ，<input type="hidden" id="checks" name="checks" value=" {foreach key=key item=item from=$content} {$item} {/foreach}" /> 

<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content} {$item} {/foreach} 

</form> 

(4) 创建 js 脚本 文件 夹 。 首 先 编写 createxmlhttp.js 文件 ， 完 成 AJAX 中 XMLHttpRequest 对 象 的 初始 化 操 

作 。 然 后 编写 check_formjs 文件 ， 定 义 check_form0 方 法 对 表单 中 提交 的 数据 进行 验证 ， 定 义 shkname() 方 法 调 
用 chkname.php 文件 实现 用 户 名 的 无 刷新 验证 ， 定 义 checkregemail(emails) 方 法 验证 邮箱 地 址 的 格式 是 否 正 确 ; 


定义 checkregtel(regtel) 方 法 验证 电话 号 码 的 格式 是 否 正 确 。 其 中 chkname0) 方 法 的 语法 如 下 : 
function chkname(){ 


if(document.getElementById('user).value—""){ // 判 断 用 户 名 表单 元 素 值 是 否 为 空 
document.getElementById('user_check').innerHTML="<font color=#FF0000> 请 输入 用 户 名 ! </font>"; // 如 果 为 空 则 输出 该 内 容 
}else{ 
var user = document.getElementById('user’).value: // 否 则 获取 用 户 名 
var url = "chkname.php?user="+user: // 定 义 url 
xmihttp.open("GET",url.true): // 通 过 GET 方法 执行 
xmlhttp.onreadystatechange = finction(|){ // 回 调 函数 
这 xmlhttp readyState 一 4){ 1/ 判断 返回 值 
var msg = xmlhttp responseText: // 获 取 返 回 值 
if(msg —'1){ // 判 断 如 果 返 回 值 为 1 
document.getElementById('user_check').innerHTML="<font color=#FF0000> 用 户 名 被 占用 ! </font>"; // 则 说 明 用 户 名 被 占用 
retum false: 
jslse if(msg — '0){ // 判 断 如 果 返 回 值 为 0 


document.getElementById('user_check').innerHTML="<font color=green> 恭 喜 您 ， 可 以 注册 !</font>": /用 户 名 可 用 
Jelse{ 

document.getElementById('user_check').innerHTMIL="<font color=green>"+msg+"</font>"; /| 输出 可 用 用 户 名 
} 
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(1) 在 模板 页 中 为 不 同 的 功能 模块 创建 超 链接 ， 并 通过 超 链 接 传递 参数 值 。 

(2) 在 动态 PHP 文件 中 ， 应 用 switch 语句 根据 超 链接 中 传递 的 参数 值 进行 判断 ， 从 而 包含 不 同 的 PHP 脚 
本 文件 ， 并 且 将 PHP 脚本 文件 对 应 的 模板 文件 名 称 通过 assign0 方 法 赋 给 指定 的 模板 变量 。 

(3) 在 模板 页 中 ， 应 用 Smarty 中 的 include 函数 加 载 模板 变量 传递 的 模板 页 。 

这 就 是 后 台 管理 系统 主页 的 设计 方法 ， 其 中 有 关 switch 语句 和 Smarty 模板 include 函数 的 详细 讲解 请 读者 
参考 本 章 实例 562， 这 里 不 再 袭 述 。 
图 设计 过 程 

(1) 创建 system 文件 夹 , 编写 Smarty 编译 、 缓存 和 配置 文件 的 存储 目录 Smarty; 编写 system.smarty.inc.php 
文件 ， 封 装 Smarty 配置 类 、ADODB 连接 和 操作 数据 库 类 ; 编写 system.inc.php 文件 ， 完 成 类 的 实例 化 操作 。 

(2) 创建 index.html 文件 ， 设 计 管理 员 登 录 页 面 ， 编写 login_ok.php 文件 ， 完 成 管理 员 的 登录 操作 。 

(3) 创建 main.php 文件 。 首 先 通过 header0 函 数 设置 页 面 的 编码 格式 ， 初 始 化 SESSION 变量 。 然 后 根据 
SESSION 变量 判断 当前 用 户 是 否 具有 访问 权限 。 接 着 ， 如 果 具 有 访问 权限 ， 则 应 用 switch 语句 根据 超 链接 传递 
的 参数 值 ， 完 成 在 不 同 页 面 之 间 的 跳 转 操作 ， 即 通过 include 函数 包含 不 同 的 动态 PHP 文件 ， 同 时 将 动态 PHP 
人 最 后 指定 模板 页 main.html， 其 代码 如 下 : 

ap) 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
session_start(); // 初 始 化 SESSION 变量 
if($_SESSION['user]!="" and $_SESSION['pass]!=""){ 1/ 判断 用 户 是 否 具 有 访问 权限 
require("system/system.ine.php"); // 包 含 配置 文件 
switch ($_GET[caption]){ /完成 在 不 同 模块 之 间 的 跳 转 操作 
case "商品 添加 ": 
include "sho_insert.php"; // 包 含 PHP 脚本 文件 
$smarty->assign('admin_phtml','sho_insert.html’); /将 PHP 脚本 文件 对 应 的 模板 文件 名 称 赋 给 模板 变量 
break: 
/| 省略 了 部 分 代码 
default: 
include "sho_update.php"; 
$smarty->assign('admin_phtml’,'sho_update.html); 
break; 
} 
$smarty->assign("title"," 后 台 管 理 系统 --".$_GET['caption']); // 定 义 模板 变量 


S$smarty->assign("caption",$_GET['caption']); 
Ssmarty->assign("type",$_GET['type')]): 


S$smarty->assign("dates",date("Y 年 m 月 d 日 ")); /将 当前 时 间 值 定义 到 模板 变量 中 
$smarty->assign("user",$_SESSION[user]): // 将 当前 登录 用 户 的 名 称 赋 给 模板 变量 
Ssmarty->display("main.html"): // 指 定 模板 页 


a echo "<script>alert(' 您 不 具备 访问 权限 ! "); window.location .href='index.html':</script>"; 
} 
?> 
(4) 创建 模板 页 main.html。 首 先 ， 输 出 PHP 动态 页 中 定义 的 模板 变量 值 ， 包 括 页 面 的 标题 〈$titte) 、 当 
前 时 间 ($dates) 和 当前 页 输出 的 模块 类 别 ($type、$caption) 。 然 后 , 通过 include 函数 加 载 模板 变量 $admin_phtml 
传递 的 模板 页 。 最 后 ， 为 后 台 管 理 系统 中 每 个 功能 模块 创建 热点 链接 ， 并 通过 超 链接 的 参数 传递 数据 ， 同 时 应 


用 Smarty 模板 中 的 escape 方法 对 传递 的 参数 值 进 行 编 码 ， 其 关键 代码 如 下 : 
<!-- 载 入 模板 文件 -> 
{include file=$admin_phtml} 
<!-- 创 建 热点 链接 --> 
<map name="Map" id="Map"> 
<area shape="rect" coords="29,41,88,62" href="mainphp?caption={" 商 品 添加 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
<area shape="rect" coords="30,71.91.90" hre 人 ="main.php?caption={" 商 品 修改 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
<area shape="rect" coords="31.99.91.118" href="main.php?caption={" 商 品 删除 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
</map> 


(5) 创建 热点 链接 中 链接 的 动态 PHP 文件 和 模板 文件 。 由 于 篇 幅 所 限 ， 这 里 不 对 这 部 分 内 容 进行 详细 讲 
解 ， 读 者 可 以 参考 本 书 光盘 。 
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心 法 领悟 568: Smarty 模板 中 的 URL 编码 。 
在 本 实例 中 ,通过 超 链接 传递 参数 值 时 ， 应 用 Smarty 模板 中 的 escape 方法 ， 对 超 链 接 传递 的 参数 值 进行 编 
码 ， 从 而 保护 传递 数据 的 安全 。 
A 高 级 | 
实例 i 
实例 569 趣味 指数 : A 克 克 太 | 


力 实例 说 明 


在 PHP 动态 页 中 ， 可 以 通过 while、do...while、for 和 foreach 语句 实现 数据 的 循环 输出 ， 而 在 Smarty 中 ， 
也 有 属于 自己 的 循环 输出 语句 foreach 和 section。 在 本 实例 中 介绍 通过 section 语句 完成 数据 的 循环 输出 ， 其 运 
行 结果 如 图 14.20 所 示 。 
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14.20 ”Smarty 模板 下 载 页 面 


力 关键 技术 
section 循环 语句 用 于 比较 复杂 的 数组 ， 其 语法 如 下 : 


{section name="sec_name" loop=$arr_name start=num step=num} 

参数 说 明 : 

name: 表示 循环 的 名 称 。 

loop: 表示 循环 的 数组 。 

start: 表示 循环 的 初始 位 置 ， 如 果 start=2， 那 么 说 明 循 环 从 loop 数组 的 第 2 个 元 素 开始 。 

step: 表示 步 长 ， 如 果 step=2， 那 么 循环 一 次 后 ， 数 组 的 指针 将 向 下 移动 两 位 ， 依 此 类 推 。 

section 循环 语句 读 取 的 是 存储 在 模板 变量 中 的 数组 元 素 , 而 这 个 数组 元 素 值 是 在 动态 PHP 文件 中 通过 调用 
数据 库 操作 类 中 的 Sadmindb->ExecSQL 方法 获取 的 。 

究 其 根源 就 是 应 用 ADODB 类 库 中 的 GetRows() 方 法 获取 的 查询 结果 ， 有 关 其 具体 的 设置 可 以 参考 封装 的 
数据 库 操 作 类 AdminDB， 该 类 存储 于 system\system.smarty.inc.php 文件 中 。 


图 设计 过 程 
(1) 本 实例 以 实例 568 中 开发 的 后 台 管理 系统 主页 为 基础 ， 首 先 去 除 后 台 管理 系统 的 登录 功能 ， 直 接 在 


index.php 和 index.html 中 编写 后 台 管理 系统 的 主页 ， 在 switch 语句 中 ， 将 vip_look.php 和 vip_ look html 设置 为 
默认 值 。index.php 的 关键 代码 如 下 : 
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</tr> 
{/section} 


在 上 述 section 语句 中 ， 将 从 数组 的 第 2 个 元 素 开 始 循环 ， 并 且 数 组 指针 一 次 向 下 移动 两 位 。 
注意 ， 在 应 用 section 语句 时 ， 一 定 要 有 {/section} 结 束 标 记 。 


力 实例 说 明 


本 实例 在 应 用 section 语句 循环 输出 数据 库 中 数据 的 基础 上 ， 增 加 一 个 分 页 功能 ， 实 现 对 数据 库 中 数据 的 分 
页 显示 ， 运 行 结果 如 图 14.21 所 示 。 
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图 14.21 Smarty 模板 中 数据 的 分 页 输出 


力 关键 技术 


在 Smarty 中 实现 分 页 与 在 PHP 文件 中 实现 分 页 的 原理 是 相同 的 ， 唯 一 的 区 别 是 ， 在 Smarty 中 分 页 的 处 理 
操作 与 分 页 的 显示 是 分 离 的 。 分 页 的 处 理 操作 存储 在 sho_delete.php 文件 中 ， 其 应 用 到 的 关键 技术 如 下 : 
(1) mysql_query0 函 数 执行 查询 、 更 改 以 及 删除 等 操作 ， 语 法 如 下 : 


i 
参数 query 为 字符 串 类 型 ， 指 定 传 入 的 SQL 指令 ; 参数 link_identfier 为 资源 类 型 ， 指 定 传 入 的 由 mysql_ 
connect0 函 数 或 mysql_pconnectO 函 数 返 回 的 连接 标识 。 如 果 省 略 该 参数 ， 则 会 使 用 最 后 一 个 打开 的 MySQL 数 
据 库 连 接 。 
(2) mysql_fetch_array0 函 数 从 数组 结果 集中 获取 数据 ， 语 法 如 下 : 


array mysql_fetch_array ( resource result [. int result_type] ) 

参数 说 明 : 

result: 资源 类 型 的 参数 ， 要 传 入 的 是 由 mysql_query0 函 数 返 回 的 数据 指针 。 

result_type: 可 选项 ， 整 数 型 参数 ， 要 传 入 的 是 MYSQL ASSOC、MYSQL NUM 和 MYSQL BOTH 这 3 
种 由 PHP 定义 的 常数 之 一 ， 默 认 值 是 MYSQL BOTH 。MYSQL ASSOC 只 得 到 关联 索引 (相当 于 
mysql_fetch_assoc(0) 函 数 ) ; MYSQL NUM 只 得 到 数字 索引 (相当 于 mysql_fetch_ row0 函 数 ) ; MYSQL _ BOTH 
将 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 。 

(3) armay0 函 数 定义 一 个 数组 ， 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 “=> ”运算 符 给 出 索引 。array0 函 

数 是 一 个 语言 结构 ， 用 于 字面 上 表示 数组 ， 不 是 常规 的 函数 ， 语 法 如 下 : 

array amray ( [mixed .了 

参数 mixed 的 语法 为 key => value， 多 个 参数 间 用 逗号 分 开 ， 分 别 定义 了 索引 和 值 。 

索引 可 以 是 字符 串 或 数字 。 如 果 省 略 了 索引 ， 会 自动 产生 从 0 开始 的 整数 索引 。 如 果 索 引 是 整数 ， 则 下 一 
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图 14.22 ”Smarty+ADODB 完成 数据 的 分 页 显示 


图 关键 技术 


应 用 Smarty+ADODB 完成 数据 的 分 页 显示 ,涵盖 了 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 的 
分 页 技术 , 而 Smarty 依旧 是 将 ADODB 操作 MySQL 获取 到 的 数据 通过 assign() 方 法 传递 给 模板 变量 ， 然 后 在 模 
板 页 中 应 用 section 语句 循环 输出 数据 。 

其 中 有 关 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 分 页 技术 的 详细 讲解 ， 请 读者 参考 本 书 第 13 
章 的 内 容 ， 这 里 不 再 灼 述 。 

在 本 实例 中 ， 将 Smarty 的 配置 方法 以 及 ADODB 连接 和 操作 数据 库 的 方法 都 存储 在 system.smarty.inc.php 
文件 中 ; 将 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 的 实例 化 存储 在 system.inc.php 文件 中 ; 将 Smarty 的 编译 文 
件 、 配 置 文件 和 缓存 文件 的 存储 目录 放置 在 Smarty 文件 夹 下 ; 而 将 Smarty 类 库 和 ADODB5 类 库存 储 在 实例 根 
目录 的 同 级 目录 下 。 本 实例 的 文件 夹 架 构 如 图 14.23 所 示 。 


日 镶 站 点 -ar OF:\AppServ\re WRN14) 
Fn 实例 根 目录 
ee- 


上 传 图 片 存 鳍 文件 志 
配置 文件 存 刍 文件 夹 
Saart7 生 成 文件 存储 文件 卖 
组 存 文件 卖 


AD0DB 类 库 文件 卖 
Seurty 模 板 文件 夷 


图 14.23 本 实例 的 文件 夹 架构 
看 设计 过 程 


(1) 创建 system 文件 夹 ， 存 储 ADODB 类 库 和 Smarty 模板 文件 。 创 建 system.smarty.inc.php 文件 ， 定 义 
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数据 库 连 接 类 、 数 据 库 操作 类 和 分 页 类 。 

数据 库 连接 类 ConnDB ， 定 义 构造 方法 ConnDB 为 成 员 变 量 赋值 ， 定 义 GetConnId0 方 法 ， 应 用 
NewADOConnection0) 函 数 连接 MySQL、mssql 或 者 Access 数据 库 ， 设 置 数据 库 编 码 格式 为 UTF-8， 最 后 返回 
数据 库 连 接 对 象 ， 定 义 CloseConnId(0 方 法 ， 关 闭 与 数据 库 的 连接 。 

数据 库 操作 类 AdminDB， 定 义 ExecSQL() 方 法 完成 对 数据 库 的 添加 、 更 新 和 删除 操作 。 首 先 ， 通 过 substr() 
函数 截取 SQL 语句 中 前 6 个 字符 串 ， 并 将 截取 的 字符 串 转换 成 小 写 。 然 后 ， 通 过 Execute0 函 数 执行 SQL 语句 。 
最 后 ， 根 据 截取 的 字符 串 判断 SQL 语句 的 类 型 ， 如 果 是 select 查询 语句 ， 则 执行 GetRows0 函 数 ， 如 果 查 询 结 
果 为 0， 则 返回 FALSE， 和 否则 返回 查询 的 数组 ， 如果 SQL 语句 为 update、insert 或 者 delete 类 型 ， 执 行 成 功 则 
返回 TRUE， 和 否则 返回 FALSE。 

分 页 类 SepPage， 定 义 ShowDate() 方 法 完成 从 数据 库 中 读 取 数据 的 操作 ， 执 行 PageExecute0 函 数 实现 分 页 
功能 ， 并 且 将 返回 值 定义 到 数组 中 ， 定 义 ShowPage() 方 法 根据 查询 结果 应 用 分 页 函数 创建 分 页 超 链接 ， 并 且 将 
返回 结果 定义 到 变量 $str 中 。 

Smarty 配置 类 SmartyProject， 继 承 Smarty 类 库 中 Smarty 类 ， 设 置 本 实例 中 Smarty 缓存 文件 、 配 置 文件 、 
模板 文件 和 编译 文件 的 存储 位 置 。 

system.smarty.ine.php 文件 的 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 这 里 不 再 介绍 。 

(2) 创建 system.inc.php 文件 ， 完 成 对 数据 库 连接 、 操 作 、 分 页 以 及 Smarty 配置 类 的 实例 化 操作 ， 其 代码 


如 下 : 

<?php 
require("system.smarty.ine.php"): /包含 配置 类 文件 
S$smarty=new SmartyProject(); /实例 化 配置 类 
$connobj=new ConnDB("mysql","localhost", "root"."111","db_database14",false); // 实 例 化 数据 库 连 接 类 
S$conn=$connobj->GetConnId(): 

admindb=new AdminDB(); // 实 例 化 数据 库 操作 类 
$seppage=new SepPage(); // 实 例 化 分 页 类 
> 


至 此 ， 有 关 ADODB 和 Smarty 的 安装 和 配置 方法 介绍 完毕 。 
(3) 创建 index.php 文件 ， 调 用 分 页 类 中 的 ShowDate0 方 法 ， 分 页 读 取 数 据 库 中 的 数据 ， 并 且 将 返回 值 赋 
给 模板 变量 ， 调 用 分 页 类 中 的 ShowPage0 方 法 ， 完 成 分 页 超 链接 的 输出 ， 同 样 将 返回 值 赋 给 模板 变量 ， 最 后 指 


定 模板 页 ， 其 代码 如 下 : 
<?php 


require_once("system/system.inc.php"): /包含 配置 文件 
S$arraybbs=$seppage->ShowDate("select * from tb_commo where isnew = 1 order by id ".Sconn.3.$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 功能 
这 !$arraybbsj{ 


Ssmarty->assign("isbbs","F"); 

jelsef 
Ssmarty->assign("isbbs","T"): 

$smarty->assign("showpage".$seppage->ShowPage(" 商 品 "" 个 ",""."a1")): // 定 义 输出 分 页 数据 的 模板 变量 showpage 
Ssmarty->assign("arr".$arraybbs): 

和 

$smarty->assign('title''Smarty+Adodb 完成 数据 分 页 显示 )); 

Ssmarty->display('index.html'); 

2> 


(4) 创建 index.html 模板 文件 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 。 
(5) 创建 showcommo.html 和 showcommo.php 文件 ， 用 于 输出 指定 产品 的 详细 信息 。 


力 秘笈 心 法 
心 法 领悟 571: 在 模板 页 中 谋 入 PHP 脚本 。 


在 Smarty 模板 页 中 也 可 以 嵌入 PHP 脚本 ,应 用 的 是 Smarty 中 的 PHP 标签 。PHP 标签 中 的 语句 是 否 被 处 理 
取决 于 Sphp_handling 的 设置 。 通 常情 况 下 是 不 需要 在 模板 页 中 嵌入 PHP 脚本 的 ， 但 是 不 代表 不 可 以 使 用 。 
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时 间 的 格式 化 输出 高 级 | 


趣味 指教 : 请 请 博 家 | 


odd 


实例 572 


力 实例 说 明 


在 PHP 脚本 中 ， 完 成 日 期 、 时 间 的 格式 化 输出 最 常用 的 是 date0 函 数 ， 那 么 在 Smarty 模板 中 该 如 何 完成 日 
期 、 时 间 的 输出 呢 ? 这 就 是 本 实例 要 讲解 的 内 容 ， 即 通过 Smarty 模板 中 的 date_format 函数 完成 日 期 、 时 间 的 
格式 化 输出 ， 其 运行 结果 如 图 14.24 所 示 。 
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图 14.24 Smarty 模板 中 日 期 的 格式 化 输出 


图 关键 技术 
(1) Smarty 模板 中 的 date_format 函数 用 于 格式 化 从 strftime0 函 数 获得 的 时 间 和 日 期 ， 其 应 用 示例 如 下 : 


{$smarty.nowldate_format:"%A, %B %e, %Y":Stimes} 

参数 说 明 : 

Ssmarty.now: 传递 给 date_format 的 数据 。 这 个 参数 可 以 是 在 PHP 动态 页 中 定义 的 日 期 、 时 间 模 板 变量 ， 
也 可 以 使 用 Smarty 中 的 保留 变量 $smarty.now 或 者 Smarty 模板 中 的 日 期 。 

%A, %B %e, %Y: date_format 函数 执行 格式 化 操作 时 使 用 的 格式 。 

$times: 当 传 递 给 date_format 的 数据 为 空 时 ， 通 过 $times 设置 date_format 格式 化 的 默认 值 。 

(2) date_format 函数 可 以 使 用 的 转换 格式 很 多 ， 其 常用 的 转换 格式 说 明 如 下 : 

%a - 根据 当地 格式 输出 “星期 ”的 缩写 格式 

%A - 根据 当地 格式 输出 “星期 ”的 全 称 格 式 

%b - 根据 当地 格式 输出 “月 ”的 缩写 格式 

%B - 根据 当地 格式 输出 “月 ”的 全 称 格 式 

%Y - 根据 当地 格式 输出 “年 ”的 全 称 格式 


要 了 解 date_format 函数 所 有 可 以 使 用 的 转换 格式 ， 建 议 读者 参考 Smarty 模板 的 参考 手册 。 
看 设计 过 程 

本 实例 继续 使 用 实例 571 的 内 容 ， 在 index.html 模板 文件 中 插入 date_format 函数 ， 输 出 系统 的 当前 时 间 ， 
其 关键 代码 如 下 : 

<td width="480" height="18" align="left"> 当 前 时 间 : {$smarty.nowldate format:" %A %B-%e-%Y"}</td> 

<!--{$smarty.nowldate_format} 

{$smarty.nowldate format:"%A, %B %e, %Y":S$times} 


{Ssmarty.nowldate_format:"%H:%M:9%S"} 
{Syesterdayldate_format} 
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{Syesterdayldate_format:"%A, %B %e, %Y"} 
本 实例 的 其 他 内 容 可 以 参考 实例 571， 这 里 不 再 次 述 。 
图 秘笈 心 ; 


心 法 领悟 572: date_format 函数 的 妙用 。 

通过 date_format 函数 不 但 可 以 输出 系统 的 当前 时 间 ， 如 果 配 合 strtotime0 函 数 还 可 以 获取 其 他 时 间 。 例 如 ， 
获取 系统 前 一 天 的 时 间 ， 其 方法 如 下 : 

首先 在 index.php 中 应 用 strtotimeO 函 数 获取 前 一 天 的 时 间 戳 ,并 且 将 时 间 戳 赋 给 模板 变量 然后 在 index.html 


模板 页 中 应 用 date_format 函数 格式 化 输出 前 一 天 的 时 间 ， 其 关键 代码 如 下 : 
Vindex.php 文件 
S$smarty->assign( yesterday' strtotime(-1 day’)); 
/lindex.html 文件 
{S$ yesterday date_format"%A %B - %e - %Y"} 


图 实例 说 明 


在 PHP 脚本 中 应 用 urlencode0 函 数 对 超 链接 中 传递 的 参数 进行 编码 ， 而 在 Smarty 模板 中 提供 escape 函数 
对 字符 串 进 行 编码 。 本 实例 将 详细 讲解 该 函数 的 应 用 ， 通 过 它 对 超 链 接 中 传递 的 参数 进行 编码 ， 其 运行 结果 如 
14.25 所 示 。 
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14.25 ”Smarty 模板 中 对 超 链 接 的 参数 值 进行 编码 


力 关键 技术 


escape 变量 用 于 HTML 转 码 、URL 转 码 ， 在 没有 转 码 的 变量 上 转换 单 引号 、 十 六 进 制 转 码 或 者 JavaScript 
转 码 ， 默 认 是 HTML 转 码 ， 其 基本 的 应 用 格式 如 下 : 


{$articleTitlelescape} 

{$articleTitlelescape: "html"} {* escapes & "'<>*} 

{SarticleTitlelescape:"htmlall"} {* escapes ALL html entities *} 

{SarticleTitlelescape:"url"} 

{SarticleTitlelescape:"quotes"} 

<a href="mailto: {$EmailAddresslescape:"hex"}">{$EmailAddresslescape:"hexentity"}</a> 


力 设计 过 程 
(1) 这 里 仍然 应 用 实例 568 中 的 内 容 ， 为 不 同 模块 之 间 跳 转 的 超 链接 传递 的 参数 值 编码 ， 其 具体 的 操作 在 
main html 模板 页 中 完成 ， 关 键 代码 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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例 以 实例 569 为 基础 ， 将 分 页 输出 的 会 员 名 称 mr 蔡 换 为 明日 科技 ， 运 行 结果 如 图 14.26 所 示 。 
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图 14.26 Smarty 模板 中 正则 表达 式 的 运用 


图 关键 技术 


regex_replace 为 Smarty 模板 中 的 正则 表达 式 ， 可 对 指定 的 字符 串 进行 匹配 ， 其 包括 两 个 参数 : 第 一 个 是 指 


定 的 正则 表达 式 ， 第 二 个 是 指定 的 蔡 换 文本 ， 其 应 用 示例 如 下 : 


{Snamelregex_replace:"/[mr]/":"<font color=#FF0000> 明 日 科技 </font>"} 


在 这 个 示例 中 ， 将 模板 变量 Sname 中 的 mr 蔡 换 为 <font color=#FF0000> 明 日 科技 </font>。 


力 设计 过 程 


这 里 以 实例 570 的 内 容 为 基础 ， 对 会 员 浏览 模块 的 内 容 进 行 重新 编辑 ， 分 页 输出 会 员 浏 览 的 数据 ， 并 且 应 


用 regex_replace 变量 将 会 员 名 称 中 的 mr 蔡 换 为 明日 科技 。 


量 ， 


802 


(1) 编辑 vip_look.php 文件 ， 分 页 读 取 数据 库 中 存储 的 会 员 数 据 ， 并 且 将 分 页 读 取 返 回 的 变量 赋 给 模板 变 


最 终 指定 模板 页 ， 其 关键 代码 如 下 : 

<?php 

include_once "conn/conn.php"; // 连 接 数 据 库 
require_once("system/system.inc.php"); // 调 用 指定 的 文件 


/执行 查询 语句 ， 从 数据 库 中 读 取 商 品 信息 
$sql=mysql_query("select count(*) as totall from tb_name ".Sconn): 
Sinfo=mysqL_fetch_array($sqD; 


Stotall=$info[totall]; // 统 计数 据 库 中 数据 总 数 

这 empty($_GET[pages]) 一 tmue | is_numeric($_GET[pages]) 一 falsc){ // 判 断 变量 pages 是 否 为 空 
Spagel=1: // 如 果 变 量 为 空 ， 则 赋值 为 1 

Jelse{ // 如 果 不 为 空 ， 则 获取 变量 的 值 
$pagel=intval($_GET[pages]): 

} 

Spagesizel=3; // 定 义 每 页 显示 3 条 记录 

if($totall <$pagesizel){ // 判 断 如 果 数 据 库 中 的 数据 小 于 每 页 显示 的 记录 数 
$pagecount1=1; // 则 定义 pagecount 变量 的 值 为 1 

jslsef 
if($totall%$pagesize1—0){ 

S$pagecountl=intval($totall/$pagesizel): // 用 总 的 记录 数 除 以 每 页 显示 的 记录 数 ， 获 取 共有 几 页 

Jelse{ 


Spagecountl=intval($totall/Spagesizel)+1; 


} 

// 将 要 输出 的 数据 赋 给 assign 模板 变量 

Ssmarty->assign("totall".$totall): 

S$smarty->assign("pagesizel".$pagesizel): 

S$smarty->assign("pagel".$pagel): 

Ssmarty->assign("pagecount1",$pagecountl): 

$query=mysql_query("select * from tb_name order by id desc limit ".($pagel-1)*$pagesizel.". Spagesizel".$conn ): 
Smyrow=mysql_fetch_array(Squery): 

Sarray=array(): // 定 义 一 个 空 数组 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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这 个 功能 ， 即 wordwrap。 在 本 实例 中 将 讲解 这 个 变量 的 应 用 ， 并 且 通 过 它 控制 页 面 中 输出 字符 串 的 行 宽 ， 其 运 
行 结果 如 图 14.28 所 示 。 
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图 14.28 每 行 显示 30 个 字符 串 的 运行 效果 


图 关键 技术 


wordwrap 指定 段落 的 宽度 〈 即 控制 一 行 显示 多 少 个 字符 ， 如 果 超 过 这 个 字符 数 则 换行 ) ， 其 默认 值 是 80 
字符 。 该 方法 包含 3 个 参数 : 

第 1 个 参数 设置 每 行 显示 的 字符 数 。 

第 2 个 参数 设置 在 约束 点 使 用 什么 字符 〈 默 认 值 是 换行 符 m) 。 

第 3 个 参数 控制 Smarty 是 截取 到 字符 串 的 末尾 ， 还 是 精确 到 指定 长 度 的 字符 ， 默 认 情况 是 截取 到 字符 串 的 


默认 值 ， 如 果 设 置 第 3 个 参数 的 值 为 TRUE， 那么 就 精确 截取 到 指定 长 度 的 字符 ， 其 应 用 的 示例 如 下 : 
{SarticleTitlelwordwrap:30} 


设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 。 
{SarticleTitielwordwrap:30:"<br>\n"} 


设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 <br>\n 进行 换行 操作 。 


{SarticleTitielwordwrap:30:"\n":true} 
设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 ， 同 时 精确 截取 30 个 字符 。 
上 述 示例 是 对 模板 变量 $articleTitle 中 存储 的 数据 进行 操作 。 
图 设计 过 程 
(1) 创建 system 文件 夹 。 首先 定义 system.smarty.inc.php 文件 , 封装 Smarty 的 配置 方法 。 然 后 定义 system. 
inc.php 文件 ， 对 Smarty 配置 类 进行 实例 化 ， 并 返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文 
件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 
〈2) 创建 ndex.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 通过 file_get_contents0 函 数 读 


取 存 储 在 文本 文件 content.txt 中 的 字符 串 ， 并 应 用 iconv0 函 数 将 字符 串 的 GB2312 编码 转换 为 UTF-8 编码 ， 同 
时 将 转换 后 的 文件 存储 到 模板 变量 中 ， 最 终 指 定 模板 页 ， 代 码 如 下 : 
<Iphp 


header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 
include("system/system.ine.php"); // 包 含 配置 文件 
Ssmarty->assign('title'"Smarty 模板 中 控制 输出 字符 串 的 行 宽 ): // 定 义 实例 标题 变量 

$str = file_get_contents('files/content.txt): // 读 取 文 本 文件 中 的 数据 


PHP 开发 实例 大 全 (基础 卷 ) 
S$smarty->assign('content iconv("gb2312"."utf-8",$str)): // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
Ssmarty->display(index html'); /指定 模板 页 
?> 
(3) 创建 index.html 模板 页 ， 通 过 模板 变量 输出 文本 文件 中 的 字符 串 ， 并 且 应 用 wordwrap 控制 每 行 显示 
30 个 字符 ， 应 用 <br>v 完成 换行 操作 ， 其 关键 代码 如 下 : 
{$contentlwordwrap:30:"<br>\n"} 


国 秘笈 心 法 


心 法 领悟 576: Smarty 模板 中 换行 符 的 转换 。 

在 应 用 wordwrap 控制 段落 中 每 行 显示 的 字符 时 ,默认 使 用 wn 为 换行 符 .。 但 是 使 用 wn 作为 换行 符 ， 在 页 面 中 
看 不 到 字符 串 换行 的 效果 , 只 有 在 查看 源 文 件 时 才能 看 出 字符 串 已 经 换行 , 所 以 在 应 用 wordwrap 控制 段落 中 每 行 
显示 的 字符 时 ， 应 该 设置 第 2 个 参数 ， 指 定 <br> 为 换行 符 ， 这 样 在 页 面 中 就 可 以 直接 看 到 段落 换行 的 效果 。 

在 Smarty 模板 中 ， 还 可 以 通过 nl2br0 函 数 将 所 有 的 换行 符 转 换 成 </br>， 其 使 用 方法 与 PHP 中 的 nl2br0) 函 
数 相同 ， 而 本 实例 中 的 字符 串 换 行 操作 也 可 以 使 用 如 下 方法 来 完成 : 


{Scontentlwordwrap:30|nl2br} 
S| | 
实例 Si 趣味 指数 : 例 依依 家 


力 实例 说 明 


在 PHP 中 ， 可 以 通过 function 创建 自 定义 函数 完成 一 些 特殊 的 操作 ， 同 样 在 Smarty 中 可 以 通过 
Tegister_object0 方 法 注册 对 象 , 在 模板 页 中 完成 一 些 特殊 的 操作 。 在 本 实例 中 通过 register_object0 方 法 注册 对 象 ， 
定义 方法 moneyFormatO 和 unHtml0, 分 别 对 留言 本 中 的 评分 进行 转 义 (保留 两 位 小 数 ) 及 对 留言 内 容 中 的 HTML 
标记 进行 转 义 ， 其 运行 结果 如 图 14.29 所 示 。 
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图 14.29 评分 和 HIML 标记 转 义 后 输出 


图 关键 技术 
(1) register_object0 方 法 注册 一 个 在 模板 中 使 用 的 对 象 ， 语 法 如 下 : 


void register_object (string object_name. object $object. armray allowed methods/properties. boolean format. array block methods) 


register_object 注册 对 象 的 参数 说 明 如 表 14.5 所 示 。 
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PHP 开发 实例 大 全 〈 基 础 卷 ) 


定义 数据 库 连接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 并 返回 操作 对 象 。 
(2) 创建 ndex.php 文件 ， 包 含 类 的 实例 化 操作 文件 ， 创 建 类 ， 定 义 评分 转 义 和 html 标记 转 义 的 方法 ， 通 


过 register_object 注册 模板 对 象 ， 完 成 数据 库 中 数据 的 分 页 读 取 ， 最 终 指定 模板 页 ， 其 代码 如 下 : 
<Iphp 


require_once("system/system.ine.php"); /调用 指定 的 文件 
class Util { 
function moneyFormat($integral) { // 将 数字 转换 成 有 两 位 小 数 的 形式 
retum str_replace (", ", number format ( Sintegral, 2 ) ); 
} 
function unHtml(S$text) { // 转 换 字符 串 中 的 HTML 标签 
$str = htmlspecialchars ( $text ); 
$str = ereg_replace ( ‘<br>", \n', $str ); 
Sstr = nl2br ( $str ); 
Sstr = ereg replace ('' ‘&nbsp;", $str ); 
Teturn $str; 
t } 
Sntil=new UtilO; // 实 例 化 对 象 
Ssmarty->register_object("Util", $ntil.null,false): // 注 册 模板 对 象 
Sarray=$seppage->ShowDate("select + from tb_guestbook order by id dese",$conn.2.$_GET["page"]); /1/ 调 用 分 页 类 ， 实 现 分 页 
这 !$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
jelsef 
$smarty->assign("iscommo","T"); // 判 断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("showpage",$seppage->ShowPage(" 留 言 "," 条 ","","a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("array",Sarray); 


a 
aa 
(3) 创建 ndex.html 模板 页 ， 分 页 输出 模板 变量 中 传递 的 数据 并 且 调用 注册 模板 对 象 中 的 方法 ， 对 评分 和 
HTML 标记 进行 转换 操作 。 同 时 创建 一 个 form 表单 ， 用 于 提交 留言 信息 ， 将 数据 提交 到 index_ok.php 文件 中 。 
关键 代码 请 参考 关键 技术 中 的 内 容 。 
(4) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 留言 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 


<?php 


header ( "Content-type: text/html; charset=UTF-8" ); 1/ 设置 文件 编码 格式 
require_once("systenmy/system.ine.php"): // 调 用 指定 的 文件 
Stitle=$_POST[title]: /获取 标题 
$content=$_POST[content]; /获取 内 容 
Sintegral=$_POST[integral]; 

Screatetime=date("Y-m-j H:i:s"); // 定 义 时 间 


Sarr=$admindb->ExecSQL("insert into tb_guestbook(title.content.createtime,integral) values (‘$title',Scontent',Screatetime','Sintegral)".$conn); 
这 S$arD{ 
echo "<script>alert(' 留 言 发 表 成 功 !):window.location .hre 人 index.php':</script>": 
jelsef 
echo "<script>alert( 留 言 发 表 失 败 !"):history.back0:</script>"; 
} 
> 


心 法 领悟 577: 模板 对 象 的 注销 。 
在 Smarty 模板 中 不 但 可 以 注册 模板 对 象 而 且 可 以 注销 模板 对 象 ， 注 销 模板 对 象 应 用 的 是 unregister_ objectO 
方法 。 
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$smarty->register function("Util" "unHtml"): /注册 模板 函数 
Sarray=$seppage->ShowDate("sclect * from tb_guestbook order by id desc".Sconn.6.$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 
这 !$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
Yelse{ 
S$smarty->assign("iscommo"."T™"): // 判 断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
S$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "" 条 ","","a1")): // 定 义 输出 分 页 数据 的 模板 变量 showpage 


Ssmarty->assign("array".Sarray): 
$smarty->assign('title',register_function(0) 方 法 注册 模板 函数 "); 
$smarty->display('index-html’): 
> 
(3) 创建 index.html 模板 页 获取 模板 变量 传递 的 数据 ， 实 现 数据 的 分 页 输出 ， 并 且 调用 动态 页 中 注册 的 
模板 函数 实现 对 论坛 内 容 的 截取 操作 ， 其 关键 代码 如 下 : 


{section name=id loop=$array} 

<tr> 

<td colspan="4" bgcolor="#FFFFFF">{$arraylid].iid }&nbsp:&nbsp:{Util text=$array[id].title } 积 分 : {$array[id] integralj&nbsp:&nbsp:&nbsp:&nbsp; 
时 间 : {$array[id].createtime}<br>{Util text=$array[id].content}</td> 

<ltr> 

{/section} 


心 法 领悟 578: 字符 串 的 截取 。 
通常 使 用 substr0 函 数 对 字符 串 进行 截取 ， 但 是 该 函数 在 截取 中 文字 符 串 时 ， 很 可 能 导致 截取 的 中 文字 符 串 


不 完整 出 现 乱码 的 情况 。 而 本 实例 中 应 用 的 mb_substr0 函 数 同样 可 以 实现 字符 串 的 截取 功能 ， 并 且 可 以 对 中 文 
字符 串 进行 截取 不 会 出 现 乱 码 的 问题 。 


高 级 | 
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实例 说 明 


在 Smarty 中 ， 提 供 了 truncate 方法 对 字符 串 进行 截取 ， 该 方法 可 以 截取 到 一 个 词 的 末尾 。 在 本 实例 中 ， 应 
用 truncate 方法 对 论坛 中 标题 和 内 容 进行 截取 ， 并 且 用 省 略 号 蔡 换 截取 的 内 容 ， 其 运行 结果 如 图 14.31 所 示 。 
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图 14.31 truncate 方法 截取 字符 串 


图 关键 技术 
truncate 方法 从 字符 串 开 始 处 截取 指定 长 度 的 字符 ， 默 认 是 80 个 字符 。 应 用 示例 如 下 : 
{SarticleTitleltruncate} <!-- 截 取 默认 长 度 的 字符 串 -> 
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力 实例 说 明 


缓存 的 合理 应 用 应 该 以 实际 的 开发 需要 为 依据 ， 对 于 那些 需要 经 常 更 新 的 程序 是 否 开启 缓存 ， 如 果 开启 组 
存 ， 周 期 长 短 设置 为 多 少 ， 这 些 都 必须 根据 程序 的 实际 需求 进行 设置 。 在 本 实例 中 ， 开 启 网 站 注册 页 面 的 缓存 ， 
注册 页 面 的 运行 结果 如 图 14.32 所 示 。 


图 14.32 注册 页 面 的 运行 结果 


图 关键 技术 


缓存 的 设置 既 要 考虑 可 以 提高 网 站 的 访问 速度 ， 又 要 考虑 缓存 生命 周期 的 合理 性 。 不 能 偏执 一 方 ， 应 该 采 
取 中 庸 之 道 ， 达 到 最 理想 的 效果 。 

例如 ， 网 站 首页 是 不 需要 经 常 更 新 的 内 容 ， 缓 存 的 生存 周期 就 可 以 设置 长 一 些 ， 而 类 似 于 论坛 中 帖子 的 数 
据 ， 则 可 以 不 开启 缓存 ， 因 为 帖子 的 数据 会 不 断 地 更 新 ， 如 果 使 用 缓存 可 能 会 导致 浏览 不 到 最 新 的 数据 。 

(1) 开启 缓存 。 开 启 缓存 的 方法 非常 简单 ， 只 要 将 Smarty 对 象 中 $config 的 值 设 置 为 TRUE 即 可 ， 同 时 还 


nn 
S$smarty->caching=true: 
S$smarty->cache dir= BASE_ PATH.SMARTY PATH.'cache/': 人 


(2) 设置 缓存 生命 周期 。 缓 存 创建 成 功 后， 必须 为 其 设置 一 个 生命 周期 ， 如 果 它 一 直 不 更 新 ， 那 么 就 没有 
任何 意义 。 设 置 缓存 生命 周期 应 用 的 是 Smarty 对 象 中 的 Scache lifetime 属性 ， 缓 存 时 间 以 秒 为 单位 ， 默 认 值 是 
3600 秒 ， 其 操作 代码 如 下 : 


S$smarty->caching=true; /开启 缓存 
S$smarty->cache_dir =BASE_PATH.SMARTY PATHcache/: // 定 义 缓存 文件 存储 位 置 
S$smarty->cache_lifetime=3600 /设置 缓存 时 间 为 1 小 时 


(3) 判断 模板 文件 是 否 已 经 被 缓存 。 如 果 页 面 已 经 被 缓存 ， 那 么 就 可 以 直接 调用 缓存 文件 ， 而 不 再 执行 动 
态 获取 数据 和 输出 的 操作 。 为 了 避免 在 开启 缓存 后 ， 再 次 执行 动态 获取 数据 和 输出 操作 给 服务 器 带 来 的 压力 ， 
最 佳 的 方法 就 是 应 用 Smarty 对 象 中 的 is_cached0 方 法 ， 判 断 指定 的 模板 是 否 存在 缓存 ， 如 果 存 在 ， 则 直接 执行 


缓存 中 的 文件 ， 否 则 执行 动态 获取 数据 和 输出 的 操作 。 ll 
Ssmarty->caching=true; 
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实例 581 


力 实例 说 明 


配置 文件 的 应 用 ， 有 利于 设计 者 管理 文件 中 的 模板 全 局 变量 。 例 如 ， 定 义 一 个 模板 色彩 变量 ， 一 般 情况 下 
如 果 想 改变 一 个 程序 的 外 观 色彩 ， 必 须 更 改 每 一 个 文件 的 颜色 变量 。 如 果 有 配置 文件 ， 色 彩 变量 就 可 以 保存 在 
一 个 单独 的 文件 中 , 只 要 改变 配置 文件 就 可 以 实现 色彩 的 更 新 , 这 与 在 Web 页 面 开 发 中 应 用 的 CSS 样式 非常 相 
似 。 在 本 实例 中 ， 将 讲解 如 何 应 用 Smarty 中 的 配置 文件 ， 并 通过 配置 文件 定义 页 面 中 body 标签 的 样式 ， 其 运 
行 结果 如 图 14.33 所 示 。 
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图 14.33 ”通过 配置 文件 定义 页 面 的 样式 


力 关键 技术 


(1) 创建 配置 文件 。 

配置 文件 可 以 任意 命名 ， 其 存储 位 置 由 Smarty 对 象 的 Sconfig_dir 属性 指定 。 如 果 存 在 不 只 在 一 个 区 域内 使 
用 的 变量 值 ， 可 以 使 用 三 引号 〈""") 将 其 完整 地 封装 起 来 。 在 创建 配置 文件 时 ， 建 议 在 程序 运行 前 使 用 “#” 
加 一 些 注释 信息 ， 这 样 有 助 于 程序 的 阅读 、 更 新 。 

在 配置 文件 中 既 可 以 声明 全 局 变量 ， 也 可 以 声明 局 部 变量 。 如 果 声明 局 部 变量 ， 可 以 使 用 中 括号 “[]” 括 起 
来 ， 在 中 括号 之 内 声明 的 变量 属于 局 部 变量 ， 而 中 括号 之 外 声明 的 变量 都 是 全 局 变量 。 中 括号 的 使 用 不 仅 使 配 
置 文件 中 声明 变量 的 模块 变 得 清晰 ， 而 且 可 以 在 模板 中 选择 加 载 中 括号 内 的 变量 。 

(2) 加 载 配置 文件 。 

加 载 配置 文件 应 用 Smarty 的 内 建 函 数 config load， 其 语法 如 下 : 

{config load file="file_name " section="add attribute" scope="" global=""} 

参数 说 明 : 

file: 指定 包含 的 配置 文件 的 名 称 。 

section: 附加 属性 ， 当 配置 文件 中 包含 多 个 部 分 时 应 用 ， 指 定 具体 从 哪 一 部 分 中 取得 变量 。 

scope: 加 载 数据 的 作用 域 , 取 值 必 须 为 local、 parent 或 global。 local 说 明 该 变量 的 作用 域 为 当前 模板 ; parent 
说 明 该 变量 的 作用 域 为 当前 模板 和 当前 模板 的 父 模板 〈 调 用 当前 模板 的 模板 ) ; global 说 明 该 变量 的 作用 域 为 
所 有 模板 。 

global: 说 明 加 载 的 变量 是 否 全 局 可 见 ， 等 同 于 scope=parent。 
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这 提示 : 当 指 定 scope 属性 时 ， 可 以 设置 global 属性 ， 但 模板 忽略 该 属性 值 ， 而 以 scope 属性 为 准 。 


(3) 引用 配置 文件 中 的 变量 。 
配置 文件 加 载 成 功 后 , 就 可 以 在 模板 中 引用 配置 文件 中 声明 的 变量 。 引用 配置 文件 应 用 的 是 “#” 或 者 Smarty 
的 保留 变量 $smarty.config， eid 


{ config load file="file_con.conf’} * 加 载 配置 文件 *} 

{title# 

<td height="228" colspan="2" align="left" valign="top" class=" {$smarty.config.styles}"> 
图 设计 过 程 


(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 存 目 录 和 配置 文件 目录 ; 创建 类 文件 
system.smarty.inc.php， 定 义 Smarty 的 配置 类 ， 在 该 类 中 指定 配置 文件 存储 的 目录 ， 定 义 类 的 实例 化 文件 
system.inc.php， 完 成 Smarty 类 的 实例 化 操作 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 通 过 文件 系统 函数 fle_get_contents0) 读 取 文本 文件 中 的 
数据 ， 并 且 将 数据 存储 到 模板 变量 中 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include("system/systenr ine.php"); // 包 含 配置 文件 

S$str = file_get_contents('files/content.txt); // 读 取 文 本 文件 中 的 数据 
S$smarty->assign('content'iconv("gb2312","utf-8",$str)); // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
Ssmarty->display(index.html'); // 指 定 模板 页 

> 


(3) 创建 index.html 模板 页 。 首 先 通过 config load0 函 数 加 载 配 置 文 件 ， 然 后 应 用 “#” 和 $smarty.config 
引用 配置 文件 中 的 变量 ， 最 后 通过 模板 变量 输出 文本 文件 中 的 数据 ， 其 关键 代码 如 下 : 


{ config load file="file_con.conf"} {* 加 载 配置 文件 *} 
<title> {#title#} </title> 
<body =" {#leftmargin#}" topmargin=" {#topmargin#}" marginwidth=" {#marginwidth#}" marginheight=" {#marginheight#}"> 
<td height="228" colspan="2" align="left" valign="top" class="{$smarty.config.styles}">{$content}</td> 
图 秘笈 心 法 


心 法 领悟 581: Smarty 模板 的 最 佳 配置 方案 。 
在 本 章 的 实例 中 , 应 用 面向 对 象 技 术 将 配置 方法 封装 到 类 中 , 应 用 Smary 模板 时 调用 类 的 实例 化 文件 即 可 。 
通过 这 种 方法 配置 Smarty 模板 ， 不 必 再 设置 服务 器 的 绝对 路 径 和 Smarty 类 库 的 绝对 路 径 ， 非 常 简单 、 方 便 。 
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[ED 说 明 : 在 文件 编码 下 拉 列 表 框 中 并 没有 GB2312 编码 , 而 GBK 编码 包含 简体 中 文 编码 ,所 以 这 里 选择 GBK 
编码 。 


完成 对 页 面 文件 的 编码 设置 后 ， 还 需要 使 用 meta 标记 设置 页 面 编码 ， 其 设置 方法 如 下 : 
<meta http-equiv= "content-type" content="text/html; charset=gb2312" /> 


设计 过 程 
(1) 创建 index.php 页 面 , 并 设置 页 面 文件 的 编码 为 GB2312, 其 具体 设置 方法 已 经 在 关键 技术 中 进行 讲解 ， 
这 里 不 再 资 述 。 
(2) 在 index.php 文件 中 通过 HTML 语言 的 meta 标记 设置 网 页 编码 为 GB2312 格式 ， 具 体 实现 代码 如 下 : 


<!IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 

</head> 

<body> 
<br> 
<div style="width: 487px; text-align:center; height:221px; line-height:221px; font-size:16px; color:blue; background:url(img/bg.jpg)"> 

这 是 一 个 GB2312 编码 格式 的 页 面 

</div> 

</body> 

</html> 


国 秘笈 心 法 

心 法 领悟 582: 在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 。 

首先 打开 Dreamweaver 开发 工具 ， 单 击 “ 编 辑 ”按钮 ， 选 择 “ 首 选 参数 ”命令 ， 在 弹出 的 “首选 参数 ”对 
话 框 中 通过 “默认 编码 ”下 拉 列 表 框 设置 创建 文件 的 编码 格式 ， 如 图 15.4 所 示 ， 设 置 完成 后 单 击 “ 确 定 ” 按钮。 


| 
USSD: [Me 
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万 党 Control43 外 全 尘 和 显 孙 “新 畦 文档 ”对 活 丁 吧 
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图 15.4 在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 


趣味 指数 : 食 食 食 


力 实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编码 格式 为 GBK。 运 行 本 实例 ,如 图 15.5 所 示 ， 在 页 面 中 打印 出 咖啡 
小 屋 程 序 所 使 用 的 页 面 编 码 。 
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Wal A 


这 是 一 个 CEFE 编 码 格 式 的 页 面 


图 15.5 打印 咖啡 小 屋 的 页 面 编码 


图 关键 技术 


本 实例 的 关键 技术 是 设置 网 页 的 页 面 编码 格式 为 GBK， 同 样 其 设置 方法 也 包括 两 个 部 分 。 首 先 设置 网 页 文 
件 的 编码 为 GBK 格式 ， 其 设置 方法 与 实例 582 相同 ， 这 里 不 再 著述 。 然 后 使 用 HIML 语言 的 meta 标记 设置 网 
页 的 编码 为 GBK， 其 设 定 代码 如 下 : 

<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
力 设计 过 程 

(1) 创建 index.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 GBK。 
(2) 在 index.php 文件 中 使 用 meta 标记 设置 网 页 编码 格式 为 GBK， 并 在 页 面 中 打印 当前 页 面 所 使 用 的 编 
码 ， 其 具体 代码 如 下 : 


<!IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 GBK 编码 格式 的 网 页 </tide> 

<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 

</head> 
<br> 
<div style="width: 498px; text-align:center; height:332px; line-height:221px; font-size:16px; color:#FF3300; background:url(img/bg.jpg)"> 

这 是 一 个 GBK 编码 格式 的 页 面 

</div> 

</body> 

</html> 


图 秘笈 心 法 
心 法 领悟 583: GB2312 和 GBK。 
GB2312 和 GBK 是 中 国政 府 颁布 的 标准 汉字 编码 。GB2312 编码 中 放置 了 6763 个 常用 汉字 ， 并 且 首 次 在 中 


文 操作 系统 CCDOS 中 使 用 ，GBK 编码 在 GB2312 编码 的 基础 上 ， 增 加 了 我 国 台湾 BIG5 编码 中 的 15000 多 个 
汉字 的 字符 。 


中 级 
趣味 指数 : 食 食 食 


实例 584 


力 实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 页 面 编码 格式 为 UTF-8。 运 行 本 实例 ， 如 图 15.6 所 示 ， 将 在 页 面 中 打印 出 企 
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业 邮 局 收发 系统 所 使 用 的 页 面 编码 。 


(OVE MB 


当前 位 置 > 电 子 莉 件 发 关 >> 状 伞 箱 


= 
和 
这 是 一 个 UTF-8 编 码 格式 的 页 面 
好友 录 


语录 


人 
15.6 ”打印 企业 邮局 收发 系统 页 面 编码 


图 关键 技术 


UTF 是 国际 字符 集 转换 格式 (Unicode/UCS Transformation Format) 的 缩写 ,是 FCS 的 实际 表达 式 ， 按 其 基 
本 长 度 所 用 位 数 分 为 UTF-8/16/32 这 3 种 形式 ， 其 中 UTF-8 保持 字符 数字 一 个 字 节 ， 其 他 的 用 不 定 长 编码 到 最 
多 6 个 字 节 ， 支 持 到 31 位 编码 。UTF 中 最 常用 的 就 是 UTF-8 编码 格式 ，UTF-8 使 用 8 位 字 节 编码 ， 通 常 使 用 
1~3 位 字 节 来 表示 一 个 字符 ， 字 符 的 编码 长 度 为 变 长 。 

UTF-8 字符 集 不 仅 包 括 欧美 字符 ， 也 包括 中 国 、 日 本 和 韩国 的 全 角 字 符 。 因 此 ， 在 网 页 中 使 用 UTF-8 字符 
集 可 以 使 用 户 在 不 安装 中 文 编码 的 情况 下 浏览 到 大 部 分 中 文字 符 。 


本 实例 设置 页 面 为 UTF-8 编码 ， 首 先 需 要 使 用 编辑 工具 设置 页 面 文件 编码 格式 为 UTF-8， 然 后 使 用 HTML 
的 meta 标记 设置 网 页 编码 格式 为 UTF-8， 其 设置 方法 如 下 : 


<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
图 设计 过 程 


(1) 新 建 ndex.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 UTF-8。 
(2) 在 HIML 语言 的 meta 标记 中 设 定 当 前 页 面 所 使 用 的 编码 格式 为 UTF-8， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 
<title> 设 计 UTF-8 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html: charset=utf-8" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<br> 
<div style="width: 978px: text-align:center: height:591px: line-height:591px: font-size:16px: color:#09600C: background:urllimg/bgjpg)"> 
这 是 一 个 UTF-8 编码 格式 的 页 面 
</div> 
</body> 
</html> 


力 秘笈 心 法 


心 法 领悟 584: Web 程序 开发 中 页 面 编码 格式 的 选择 。 


为 了 便于 程序 的 国际 化 及 使 程序 支持 更 多 语言 版 本 的 操作 系统 ， 在 项 目 开 发 中 建议 将 页 面 设置 为 UTF-8 编 
码 格式 。 
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实例 585 


力 实例 说 明 


信息 全 球 化 的 高 速 发 展 ， 使 企业 的 市 场 也 在 逐步 扩大 ， 并 逐渐 走向 世界 。 企 业 向 世界 展示 自己 ， 必 不 可 少 
地 要 应 用 到 互联 网 ， 在 应 用 互联 网 的 过 程 中 必须 要 提供 多 国语 言 的 支持 。 只 有 这 样 才 能 让 更 多 的 人 了 解 企业 。 
所 以 在 开发 程序 的 过 程 中 ， 必 须要 提供 对 多 国语 言 的 支持 。 本 实例 以 一 个 简单 的 企业 内 部 管理 系统 为 例 ， 介 绍 
如 何 通过 PHP 语言 开发 提供 多 国语 言 支持 的 程序 。 在 实例 中 ， 实 现 文章 的 添加 和 浏览 功能 ， 并 且 提供 对 中 文 和 
英文 两 种 语言 的 支持 。 中 文 文章 添加 页 面 如 图 15.7 所 示 ， 英 文 文章 添加 页 面 如 图 15.8 所 示 。 


EW | Woo | EW | ete 
图 15.7 中文 文章 添加 页 面 图 15.8 英文 文章 添加 页 面 
图 关键 技术 
本 实例 中 应 用 到 的 关键 技术 如 下 : 


(1) 网 页 编码 的 设置 。 在 网 页 中 , 字符 编码 通过 <head> 标 签 中 <meta> 标 签 的 charset 属性 来 设置 ,代码 如 下 : 


<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 设 置 网 页 编码 格式 </title> 

</head> 

<body> 通 过 meta 标签 的 charset 属性 设置 字符 编码 格式 </body> 
</html 


(2) 获取 客户 端 语言 选项 ， 根 据 语言 选项 的 值 调 用 不 同 的 语言 配置 文件 ， 代 码 如 下 : 


session start(): 
Slang=$_SERVER['HTTP_ACCEPT LANGUAGE": /获取 语言 选项 
Slang=explode(';', Slang); te i 
Slang=$lang[0]; // 为 数组 虐 
Slang=explode(',, Slang); 1 对 字符 进行 分 了 
Slang=$lang[0]: // 为 数组 赋值 
switch($lang){ /根据 获取 到 的 语言 选项 的 值 为 变量 赋值 
Case "en-us": 

Slang="en' 

break; 
case "zh-cn": 

Slang="ch 
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Slang="en"; 
break; 
} 
这 isset($_SESSION[lang])){ 
Slang=$_SESSION[lang']: // 为 SESSION 变量 赋值 
} 
include "lang/lang_ $lang php"; // 调 用 不 同 的 语言 配置 文件 


> 


其 中 ，$_SERVER['HTTP_ACCEPT LANGUAGE'] 为 服务 器 变量 ， 用 于 获取 客户 端 浏览 器 的 语言 设置 
图 设计 过 程 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 数据 库 的 连接 ， 其 代码 如 下 : 
<?php 
$conn=mysql_connect("localhost","root","111") or die(' 连 接 失败 . mysql_error0);: 
mysql_select_db("db_database15",Sconn) or die (数据 库 选择 失败 . mysql_error0): 
mysql_query("set names gb2312"); 
?> 


(2) 创建 lang 文件 夹 , 编写 lang_ch.php 和 1lang_en.php 文件 , 分 别 定义 中 文 语 言 配置 和 英文 语言 配置 文件 ， 
代码 请 参考 附送 光盘 中 的 内 容 。 

(3) 创建 config.php 文件 ， 获 取 浏览 器 中 语言 选项 的 值 ， 根 据 语言 选项 的 值 调用 不 同 的 语言 配置 文件 。 其 
完整 代码 可 以 参考 关键 技术 中 的 内 容 。 

(4) 创建 setlang.php 文件 ， 根 据 超 链接 中 传递 的 参数 为 SESSION 变量 赋值 ， 并 且 调 用 不 同 的 操作 页 面 ， 


其 代码 如 下 : 
<?php 
session start(); 
switch($_GET['lang]){ // 获 取 超 链接 传递 的 语言 选项 的 值 
让 “$_SESSION[lang]="en"; // 根 据 超 链 接 的 值 为 SESSION 变量 赋值 
break; 
ease "ch": 


$_SESSION['lang']="ch": 
break: 


default : 
$_SESSION[ lang']="en"; 
break; 


} 

if($_GET[link]—"addnew"){ // 根 据 超 链接 的 值 跳 转 到 不 同 操作 页 面 
header("Location:addnew.php"); 

Yelseif ($ GETTTink1 一 "show"f 
header("Location:show.php"): 

Jelse{ 


header("Location:index.php"): 

} 

?> 

(5) 创建 index.php 文件 ， 根 据 选择 的 语言 不 同 输出 不 同 的 页 面 和 内 容 。 首 先 通 过 require_once 语句 调用 
不 同 的 包含 文件 ， 完 成 数据 库 连接 和 语言 配置 。 然 后 执行 查询 操作 ， 从 数据 表 中 读 取 指 定 的 数据 信息 。 最 后 在 
页 面 中 输出 数据 ， 其 关键 代码 如 下 : 


<?php 

require_once('conn/conn .php)): // 连 接 数据 库 
require_once('config.php"); // 调 用 语言 配置 文件 
$query_rs="select * from tb_articles where langver=$rs_filter order by id desc": /定义 查询 语句 
S$rs=mysql_query($query_rs.$conn) or die(mysql_errorO): // 执 行 查询 操作 
Srow_rs=mysql_fetch_assoc($rs); // 获 取 查 询 结 果 的 记录 数 


(6) 创建 add_dataphp 文件 ， 添 加 form 表单 用 于 提交 数据 并 完成 对 表单 中 数据 处 理 的 操作 。 首 先 通过 
require_once 语句 调用 不 同 的 包含 文件 ,完成 数据 库 连 接 和 语言 配置 。 然 后 定义 方法 GetSQLValueString0 完 成 对 数 
据 格 式 的 转换 。 接 着 获取 表单 中 提交 的 数据 ， 并 应 用 sprintf0 函 数 和 GetSQLValueString0 方 法 完成 对 数据 格式 的 转 
换 将 数据 添加 到 数据 表 中 。 最 后 设计 文章 添加 页 面 ， 创 建 form 表单 ， 完 成 数据 的 提交 操作 ， 其 关键 代码 如 下 : 
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图 15.9 明日 科技 书店 成 功 连接 MySQL 数据 库 的 首页 运行 效果 


图 关键 技术 


本 实例 的 关键 是 设计 一 个 可 以 对 多 种 数据 库 进行 连接 的 数据 库 连 接 类 。 下 面 对 数据 库 连接 类 的 制作 方法 进 


行 详细 讲解 : 
(1) 首先 定义 数据 库 连 接 类 的 属性 ， 关 键 代码 如 下 : 

var $dbType; /| 数据库 类 型 标识 
var $host; /数据库 服务 器 地 址 
Var $userName; /| 数据 库 服务 器 用 户 名 
var $password: /数据 库 用 户 密码 
var $dbName; // 要 连接 的 数据 库 名 
var $isDebug; /是 否 显示 调试 信息 
var $connID 


上 加 说 明 : 这 里 为 了 兼容 PHP 5.0 以 下 的 版 本 ， 所 有 属性 都 定义 成 var 类型。 
(2) 定义 数据 库 连 接 类 的 构造 方法 ， 实 现 对 类 内 属性 的 初始 化 ， 其 关键 代码 如 下 : 


function ConnDB ($dbType = 'mysql', $host, $userName, $password, $dbName, SisDebug = false){ 
Sthis->dbType = $dbType: // 为 数据 库 类 型 赋 初 值 


S$this->host = $host; // 为 服务 器 地 址 赋 初 值 
S$this->userName = $userName; // 为 用 户 名 赋 初 值 
S$this->password = $password; // 为 密码 赋 初 值 
Sthis->dbName = $dbName; // 为 数据 库 名 赋 初 值 
S$this->isDebug = $isDebug; // 为 调试 信息 赋 初 值 


} 


[上 说 明 : 上 述 代码 中 的 “->” 是 PHP 面向 对 象 编程 方式 中 ， 实 例 化 的 对 象 引用 类 中 方法 或 属性 的 标识 符 。 


(3) 通过 ConnDBO 构 造 方法 对 类 中 属性 初始 化 后 ， 就 可 以 实现 与 数据 库 的 连接 。 具 体 连 接 过 程 通过 方法 
getConnIDO 实 现 ， 在 该 方法 中 根据 属性 SdbType 的 值 来 判断 要 连接 数据 库 的 类 型 ， 并 根据 不 同 的 数据 库 类 型 选 
择 相应 的 数据 库 连接 驱动 最 终 返回 连接 对 象 ， 其 关键 代码 如 下 : 


function getConnID O{ 
require_once Hibraryladodbladodb inc php': 


Sthis->connID = NewADOConnection($this->dbType): 
if($this->dbType 一 mysql || $this->dbType 一 mssql) { 


// 导 入 ADODB 类 库 
// 生 成 数据 库 连接 对 象 
// 如 果 为 MySQL 数据 库 或 者 SQL Server 数据 库 


S$this->connID->Connect($this->host. $this->userName. $this->password, $this->dbName): // 通 过 Connect0 方 法 建立 与 数据 库 的 连接 


if (Sthis->dbType — ‘mysql) { 


Sthis->connID->Execute('set names gb2312"): 


} 
} elseif (Sthis->dbType 一 access) { 


// 设 置 数据 库 编码 
// 如 果 为 Access 数据 库 
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图 15.10 图书 信息 简介 


图 关键 技术 


在 数据 库 管理 类 AdminDB 中 ， 只 有 一 个 名 为 executeSQL( 的 方法 , 通过 该 方法 可 以 实现 对 数据 库 的 所 有 查 
询 和 维护 操作 ， 其 关键 代码 如 下 : 


class AdminDB{ 
function executeSQL ($sql, $connID){ 


$sqlType = strtolower(substr(trim($sql), 0, 6)); /| 提取 SQL 语句 的 类 型 
Srs = $connID->Execute($sql); /| 执行 SQL 语句 
ff($sqlType = 'select) { // 如 果 是 select 查询 
SarrayData = $rs->GetRows(); // 返 回 查询 记录 集 
if(count($arrayData) 一 0 || $rs — false) { // 如 果 没 查询 到 或 发 生 错误 
return false; // 返 回 FALSE 
}else{ /否则 
return $arrayData; // 返 回 记 录 集 


} 
} elseif ($sqlType 一 insert || $sqlType — ‘update’ || $sqlType — ‘delete’) { 

// 如 果 执行 插入 、 更 新 或 删除 语句 

retum $rs; // 返 回 语句 执行 状态 ， 即 成 功 返 回 TRUE， 失 败 返 回 FALSE 
}else{ 

returm false; // 如 果 不 是 上 述 查 询 ， 则 返回 FALSE 
} 


} 
上 述 数 据 库 管理 类 中 的 executeSQL0 方 法 包含 $sql 和 $connID 两 个 参数 ， 分 别 为 要 执行 的 SQL 语句 和 数据 
库 连接 对 象 。 在 函数 体内 ， 首 先 将 传 入 的 SQL 语句 转换 成 小 写 ， 然 后 提取 SQL 语句 的 前 6 个 字符 ， 同 时 通过 
数据 库 连 接 对 象 的 Execute0 方 法 执行 SQL 语句 ， 并 根据 提取 的 SQL 语句 的 前 6 个 字符 判断 SQL 语句 的 类 型 ， 
从 而 返回 查询 结果 。 
看 设计 过 程 
(1) 建立 数据 库 管 理 类 AdminDB， 该 类 的 创建 过 程 已 经 在 本 实例 的 关键 技术 中 进行 了 详细 介绍 ， 这 里 不 
再 袭 述 ， 然 后 使 用 new 关键 字 对 该 类 进行 实例 化 ， 实 现代 码 如 下 : 
SadminDB = new AdminDBO: 
(2) 使 用 AdminDB 类 实例 的 对 象 调 用 该 类 中 的 executeSQL0 方 法 执行 查询 ， 并 将 查询 结果 赋 给 视图 变量 ， 
实现 该 过 程 的 关键 代码 如 下 : 


S$bookinfo = $adminDB->executeSQL("select tb_bookinfo.id as bid. bookname, bookids, page, isbn. zs. bookce, be about, directory. writer, pubname, 
Pubtime, bookimg, typename, oldprice, newprice from tb_boakinfo tb_pub, tb_smalltype where tb_bookinfo pubid =tb_pub.id and 
tb_bookinfo.smalltypeid = tb_smalltype.id and tb_bookinfo.id="™ . $bid . "", $connID): // 查 询 图 书信 息 
S$smarty->assign('bookinfo', $bookinfo); // 将 图 书信 息 赋 给 视图 变量 

(3) 在 bookinfo.phtml 视图 文件 中 ， 根 据 传递 的 视图 变量 的 值 打印 图 书 的 各 项 信息 ， 其 具体 实现 代码 请 详 


见 本 书 附带 光盘 。 
图 秘笈 心 ; 
心 法 领悟 587: 根据 select、update 和 delete 关键 字 的 字符 串 长 度 完成 SQL 语句 类 型 的 判断 。 
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SarrayPageInfo['countPage'] = $countPage: /总 页 数 
$arrayPageInfo['first]= 1: /第 一 页 的 页 码 
if(Spage> 1) { 
SarrayPageInfo['previous'] = $rs->AbsolutePage() - 1: 1/ 前 一 页 的 页 码 
Yelse{ 
SarrayPageInfo[ previous] = 1; 
} 
es < $countPage) { 
arrayPageInfo['next] = $rs->AbsolutePage() + 1; // 后 一 页 的 页 码 
} 
SarrayPageInfo['next] = $countPage; 
} 
SarrayPageInfo['last] = $countPage; // 最 后 一 页 的 页 码 
} 
return $arrayPageInfo; 


} 

上 述 分 页 类 实现 的 原理 是 : 设法 使 用 ADODB 数据 抽象 层 获取 指定 页 码 中 所 显示 的 数据 ， 同 时 将 首页 、 上 
一 页 、 下 一 页 、 尾 页 、 总 页 码 和 总 记录 数 都 作为 数组 元 素 ， 然 后 将 该 数组 作为 分 页 类 中 实现 分 页 方法 的 返回 值 
返回 ， 在 需要 分 页 的 模块 ， 只 需要 通过 分 页 类 获取 该 返回 数组 就 可 以 获得 所 有 分 页 所 需 信息 。 

在 实现 上 述 PageDB 分 页 类 时 ， 在 类 体内 只 定义 一 个 pageData0 分 页 方法 ,在 该 方法 内 部 , 通过 ADODB 数 
据 抽象 层 根据 分 页 方法 的 SpageSize 和 $page 参数 获取 页 面 显示 的 数据 和 分 页 导航 参数 ， 并 保存 到 $arrayPageInfo 
数组 中 返回 。 


图 设计 过 程 

(1) 建立 数据 库 分 页 类 PageDB， 并 在 该 类 中 建立 pageData() 方 法 ， 该 类 的 创建 过 程 已 经 在 关键 技术 中 给 
出 ， 这 里 不 再 效 述 。 

(2) 在 listsepbook.php 文件 中 ， 包 含 网 站 头 文件 ， 根 据 超 链接 传递 的 参数 值 为 变量 赋值 ， 调 用 数据 库 管 理 
类 中 的 方法 执行 查询 语句 ， 并 且 将 返回 的 查询 结果 赋 给 模板 变量 。 定 义 分 页 变量 ， 调 用 分 页 类 中 的 方法 完成 数 
据 的 分 页 输出 ， 同 时 将 分 页 方法 返回 的 数据 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 


require_once header.php'; // 包 含 header.php 文件 
if($_GET[t] = new') { // 展 示 新 书 
Snowtype = 新 书 推荐 ; 
Sandwhere = "isnew = 1"; 
} elseif ($_GET[+] — ee) { // 展 示 特价 图 书 
Snowtype = 特价 


Sandwhere = ee 1"; 
} elseif ($_GET[Y] 一 ‘hotsell) { 
Snowtype= ' 热 卖 图 书 ; /展示 热卖 图 书 
Sandwhere = "ishotsell = 1"; 
} elseif ($ eles ‘term) { 
书 '; 


} elseif ($_GETI+]— Sbook { /展示 明日 图 书 
Snowtype =' 明 日 图 书 推荐 '; 
Sandwhere = "ismrbooktj = 1": 
} 
S$smarty->assign('gt, $_GET[t]): // 为 模板 变量 赋值 
S$smarty->assign('nowtype', $nowtype): 
S$system = $adminDB->executeSQL("select bookimgurl, readurl from tb_system where mark = 1", $connID); /执行 查询 语句 


Ssmarty->assign('system', $system); // 将 查询 结果 赋 给 模板 变量 
if(! isset($_GET['page')) || $_GET['page] —") { 1/ 判断 分 页 变量 的 值 
ee // 设 置 分 页 变量 的 值 


}else{ 
, Spage =$_GET['page']: 

$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo_about tb_bookinfo.browsertime. tb_bookinfo.oldprice, tb_bookinfo.newprice, 
tb_bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime. tb_bookinfo.addtime, tb_bookinfo ishave. tb_pub.pubname from tb_bookinfo. tb_pub 
‘where tb_bookinfo.pubid = tb_pub.id and " . $andwhere . " order by tb_bookinfo.addtime desc": // 定 义 查询 语句 

Sbookinfos = SpageDB->pageData($sql. $connID. 10. Spage): // 调 用 分 页 类 中 的 方法 ， 执 行 查询 操作 
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上 述 代 码 首 先 通过 函数 require_once0 包 含 Smarty 类 库 中 的 Smarty.class.php 文件 ， 从 而 将 Smarty 类 库 导 入 

到 工程 中 ， 然 后 定义 SmartyConfig 类 ， 使 之 继承 自 Smarty 类 ， 在 该 类 的 构造 方法 中 ， 首 先 通过 $this 关键 字 调 
用 父 类 的 构造 方法 ， 实 现 对 Smarty 模板 引擎 的 初始 化 ， 然 后 使 用 Sthis 关键 字 分 别 调用 Smarty 模板 中 的 属性 对 
模板 路 径 进行 配置 。 
图 设计 过 程 

(1) 下 载 Smarty 模板 类 库 ， 将 其 中 的 libs 文件 夹 复制 到 项 目的 library\smarty 文件 来 下 。 

(2) 在 library\smarty 文件 夹 下 创建 cache_dir、compile_dir 和 config dir 这 3 个 文件 夹 ， 用 于 存储 Smarty 
的 缓存 文件 、 编 译文 件 和 配置 文件 。 


(3) 在 library 文件 夹 下 创建 SmartyConfig.php 文件 ， 编 写 Smarty 模板 引擎 配置 类 SmartyConfig， 其 代码 
可 以 参考 关键 技术 中 的 内 容 。 


力 秘笈 心 ; 
心 法 领悟 389: 读者 需 自行 下 载 Smarty 模板 类 库 。 


由 于 Smarty 模板 类 库 属于 第 三 方 组 件 ， 所 以 在 光盘 源 程序 中 没有 提供 ， 需 要 读者 自行 下 载 ， 并 且 将 下 载 文 
件 中 的 libs 文件 夹 复制 到 项 目的 library\smarty 文件 夹 下 。 


力 实例 说 明 


在 制作 明日 科技 书店 网 站 时 , 很 多 模块 都 需要 实现 对 中 文字 符 串 的 截取 、HTML 标记 的 原样 输出 、 CKEditor 
在 线 编辑 器 的 调用 等 功能 。 为 了 提高 代码 的 重用 率 ， 可 将 上 述 功 能 封装 成 字符 串 处 理 类 。 明 日 网 上 书店 新 书 推 
荐 中 图 书 名 称 的 输出 、 图 书 价格 的 输出 ， 以 及 新 闻 公 告 中 新 闻 标 题 的 输出 都 应 用 了 字符 串 类 中 的 方法 ， 其 运行 
效果 如 图 15.13 所 示 。 
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15.13 ”字符 串 类 中 方法 的 应 用 


力 关键 技术 


在 字符 串 处 理 类 Util 中 定义 多 个 方法 ， 分 别 实现 对 货币 格式 化 、 对 HIML 标记 进行 转 义 输出 、 对 中 文 进行 
截取 、 防 止 出 现 乱码 等 。Util 类 中 的 方法 如 表 15.1 所 示 。 
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fanction msubstr ($str, $start, $len){ 
Sstrlen = $start + $len; 
for ($i=0; $i< $strlen: $i ++) { 
ff(ord(substr($str, $i, 1)) > 0xa0) { 
Stmpstr .= substr($str, $i, 2): 
Si++; 
} else 
Stmpstr = substr($str, $i, 1): 
} 
Tetum $tmpstr; 
} 


/获取 截取 字符 长 度 

// 遍 历 所 有 字符 

// 判 断 是 否 为 中 文字 符 

// 如 果 是 中 文 则 截取 2 个 字 节 


/不 是 中 文 则 截取 1 个 字 节 
/返回 结果 


(7) 使 用 HTML 语言 提供 的 文件 域 对 文本 进行 编辑 。 实 现 文本 特效 较 复杂 ， 而 且 不 能 达到 “所 见 即 所 得 ” 
的 效果 ， 为 了 解决 上 述 问题 ， 在 进行 Web 项 目 开 发 时 ， 一 般 使 用 CKEditor 在 线 编辑 器 作为 表单 的 文本 编辑 域 。 
在 制作 明日 科技 书店 时 会 在 很 多 模块 使 用 线 编辑 器 , 所 以 在 开发 时 将 调用 CKEditor 编辑 器 的 代码 封装 在 Util 字 


符 串 处 理 类 中 ， 具 体 代码 如 下 : 
function editor ($name, $value, $width ='100%', Sheight='200){ 

require_once ibrary /fckeditor /fckeditor.php': 
SarrayIni = $this->arrayIni; 
S$oFCKeditor = new FCKedit 
SFCKeditor >BasePath = $arrayIni['baseUrl'] . /library/fckeditor/'; 
S$oFCKeditor->Width = $width:; 
SoFCKeditor->Height = $height:; 
S$oFCKeditor->ToolbarSet= ' Default': 
S$oFCKeditor->Value= $value; 
S$oFCKeditor->Create0; 


// 导 入 CKEditorr 类 库 
// 获 取 配 置 文件 内 容 
/实例 CKEditor 

// 设 置 CKEditor 路 径 
/| 编辑 器 的 宽度 

// 编 辑 器 的 高 度 

1/ 设置 工具 栏 样式 
// 初 始 值 

// 创 建 编辑 器 


} 
(8) 完成 Util 类 的 封装 ， 在 lzh.inc.php 文件 中 应 用 Smarty 中 的 register_object0 方 法 将 其 注册 为 模板 对 象 ， 
在 模板 页 中 通过 模板 对 象 调用 类 中 方法 实现 对 字符 串 的 操作 。 
在 lzh.inc.php 文件 中 不 只 实现 注册 模板 对 象 的 功能 ， 所 有 类 的 实例 化 操作 都 在 该 文件 中 完成 ， 并 返回 实例 
化 对 象 ， 包 括 数据 库 连 接 类 、 数 据 库 操 作 类 、 分 页 类 和 Smarty 配置 类 ， 其 代码 如 下 : 


<2php 
session_start(); 

SarrayIni = parse_ini_file('config/lzhConfig.ini’); 
require_once ‘library/ConnDB.php'; 
require_once ‘library/AdminDB.php'; 
require_once "library/PageDB.php'; 

require_once ‘library/SmartyConfig.php'; 
require_once library/Cart.php'; 

require_once ‘library/Util.php’; 


// 初 始 化 SESSION 变量 
// 包 含 配置 文件 

// 载 入 数据 库 连接 类 文件 
// 载 入 数据 库 操作 类 文件 


// 载 入 字符 串 处 理 类 文件 


SconnDB = new ConnDB($arrayIni[' dbType'] ,SarrayIni[host] .SarrayIni[userName'] .SarrayIni['password'] ,SarrayIni['dbName'] ,SarrayIni['isDebug’]);: 


$connID = $connDB->getConnID(): 

SadminDB = new AdminDBO: 

SpageDB = new PageDB0; 

Ssmarty = new SmartyConfig(); 

Sutil = new UtilO: 
$smarty->register_object(util'. $util, null, false): 


// 执 行 与 数据 库 的 连接 
/| 数据 库 操作 类 实例 化 
// 分 页 类 实例 化 
//Smarty 配置 类 实例 化 
/| 字符 串 操作 类 实例 化 
// 注 册 模板 对 象 


(9) 在 index.php 文件 中 ， 调 用 数据 库 操作 类 中 的 方法 ， 查 询 出 数据 库 中 的 数据 ， 并 且 将 查询 结果 赋 给 模 


板 变量 ， 最 终 指定 模板 页 。 
(10) 在 模板 页 views\index.phtml 中 ， 


用 字符 串 类 中 的 方法 对 输出 的 图 书 标题 、 图 书 价格 和 公 


{section name=rID loop=$reads} 
<div style="width:198px: padding-bottom: 7px"> 
<div style="width:100%: height:90px"> 
<div style="width:85px: height:100px: float:left"> 


应 用 section 语句 循环 输出 模板 变量 中 的 数据 ， 并 且 通 过 注册 对 象 调 
告 标题 等 进行 格式 化 操作 ， 其 关键 代码 如 下 : 


<a href=" {util->baseUrl}/bookinfo-{$reads[rID].bookid} html"><img sre="{$system[0].bookimgurl}/ {S$reads[rID].bookimg}" 


width="70" height="90" style="border: lpx solid #123456" /></a> 
</div> 


<div style="width:112px: height:100px: floatright text-align:left"> 
<li style="display:inline: height:35px"><a href=" {util->baseUrl} /bookinfo-{S$reads[rID].bookid} html" class="a6">* {util->unHtml 


p=$reads[rID].bookname} </a></li> 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<php 
Tequire_once ‘lzh.inc.php'; // 包 含 类 的 实例 化 文件 
SrequestPageName = basename ( $ SERVER ['PHP SELF]): 1/ 获取 当前 文件 的 名 称 
switch ($requestPageName) { // 根 据 当 前 文件 的 名 称 定义 页 面 的 标题 
case ‘index.php' : 

$title =' 明 日 网 上 书店 - 国内 信誉 一 流 的 IT 类 图 书 网 上 专营 店 ， 最 全 面 、 最 资深 的 网 上 书店 ! '; 

break; 
case bookinfo.php': 


Stopbookinfo = $adminDB->executeSQL("select bookname from tb_bookinfo where id=".$_GET['bid].™", $connID): 
S$title =' 明 日 网 上 书店 -'.$topbookinfo[O][bookname]; 
break: 

case "listbook.php': 
Stopsmalltypeinfo = $adminDB->executeSQL("select typename from tb_smalltype where id=".$_GET['stid]."", SconnID): 
$title =' 明 日 网 上 书店 -，. $topsmalltypeinfo[0]['typename'] .， 类 图 书 ': 


break; 
case ‘listsepbook.php': 
S$topt = $_GET[t]: 
if($topt — ‘new){ 
Stitle =' 明 日 网 上 书店 - 新 书 推荐 
} 
/省 略 了 部 分 代码 
Ssmarty->assign('title’, $title); // 将 标题 的 内 容 赋 给 模板 变量 
ifisset($_SESSION[unc]) && $_SESSION[unc]'="){ /判断 当前 用 户 是 否 为 空 
Ssmarty->assign('isLogin', T"); // 如 果 当 前 用 户 不 为 空 ， 则 为 模板 变量 赋值 
S$smarty->assign('une', $_SESSION[unc]); // 并 且 将 当前 用 户 名 称 赋 给 模板 变量 
} 
function getSidByBid(Sparams){ // 创 建 自 定义 函数 
extract($params); 
global $adminDB, SconnID; // 定 义 变量 范围 
$stype = $adminDB->executeSQL("select id from tb_smalltype where bigtypeid=".$bid." order by addtime limit 0, 1", $connID); 
return $stype[0][id]: 1/ 获取 攻 值 
} 
S$smarty->register_function('getSidByBid', ‘getSidByBid’); // 注 册 模 板 函 数 
SbigtypeDhs = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime". SconnID); /执行 查询 操作 
S$smarty->assign('bigtypeDhs', $bigtypeDhs): // 将 查询 结果 赋 给 模板 变量 
if($requestPageName 一 'index.php){ // 根 据 当前 文件 名 称 为 变量 $db 赋值 
Sdh = "index'; 


jelseif ($requestPageName 一 ‘listsepbook.php'){ 
if($_GET[t] — new){ 
$dh= mew': 
}elscif ($_GET[+] = 
$dh='sepprice'; 
}elscif ($_GET['t] = hotsell){ 
$dh = hotsell'; 
yelseif ($_GET[t] — "term){ 
$dh= term’; 


‘sepprice){ 


1! 
}elseif ($requestPageName 一 ‘listreadbook php){ 


Sdh = "listread': 

} 

Ssmarty->assign('dh', $dh): // 将 变量 值 传递 到 模板 变量 
if($requestPageName 一 'search php){ 


这 $_GET[stype] = 'simple){ 
Skeytxt = urldecode(str_replace('@'. %'. $_GET[keyWord"]): 
jelseif ($_POST['stype] = ‘simple){ 
Skeytxt = $_POST[keyWord]: 
上 
Ssmarty->assign(keytxt’, Skeytxt); 
Ssmarty->display ( header phtml): // 指 定 模板 页 
(2) 创建 模板 页 views\header.phtml， 设计 网 站 头 文件 的 页 面 ， 输 出 模板 变量 中 传递 的 数据 ， 其 代码 请 参考 


本 书 光盘 ， 这 里 不 再 疯 述 。 
国 秘笈 心 法 
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心 法 领悟 591: 通过 include 语句 包含 网 站 的 头 文件 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 


S$systemBottom = $adminDB->executeSQL("select bq, icp from tb_system where mark = 1". $connID): 
S$smarty->assign('systemBottom', $systemBottom):; 

Ssmarty->display('footer.phtml’); 

$connDB->closeConnID(); 


(2) 在 views 文件 夹 下 新 建 footer.phtml 模板 文件 ， 输 出 模板 变量 中 存储 的 系统 信息 ， 同 时 创建 常用 功能 
的 超 链 接 ， 其 代码 请 参考 本 书 光盘 。 


心 法 领悟 392: 应 用 require_once 语句 包含 文件 。 

require_once 语句 是 require 语句 的 延伸 ， 其 功能 与 require 语句 基本 类 似 ， 不 同 的 是 ， 在 应 用 require_once 
语句 时 会 先 检查 要 包含 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 包含 ， 如果 是 ， 则 不 会 再 次 重复 调用 该 文件 。 

include_once 语句 和 require_once 语句 的 用 途 是 确保 一 个 被 包含 文件 只 能 被 包含 一 次 。 使 用 这 两 个 语句 可 以 
防止 意外 地 多 次 包含 相同 的 函数 库 ， 避 免 因 函数 的 重复 定义 产生 的 错误 。 但 两 者 之 间 是 有 区 别 的 : include_once 
语句 在 脚本 执行 期 间 调用 外 部 文件 发 生 错 误 时 产生 一 个 警告 ， 而 require_once 语句 则 导致 一 个 致命 错误 。 

include_once 和 require_once 语句 在 大 小 写 不 敏感 的 操作 系统 中 (如 Windows) 的 行为 可 能 不 是 所 期 望 的 。 


" | | 
国 实例 说 明 

明日 科技 图 书 网 的 首页 中 有 一 个 循环 播放 的 广告 位 , 本 实例 实 
现 3 个 广告 的 循环 播放 , 并 且 每 个 广告 链接 不 同 的 文件 , 其 运行 效 
果 如 图 15.18 所 示 。 
图 关键 技术 


首页 广告 的 设计 应 用 的 是 js 脚本 技术 ， 控 制图 片 的 展开 方法 ， 完 成 图 片 的 循环 播放 ， 其 调用 的 是 一 个 已 经 
定义 好 的 js 脚本 lzhScrollImgjs。 
在 模板 页 中 还 要 设置 一 些 参 数 ， 关 键 代 码 如 下 : 


<script language="javascript"> 


var w="515px"; // 广 告 宽度 
varh="150px"; // 广 告 高 度 
var bg = "#99CCFF"; /广告 背 景色 
var imgSre = new Array: // 图 片 地 址 


var imgLink = new Array: // 图 片 链 接地 址 
imgLink[0] = ‘http://www.mrbooks.cn'; 

imgLink[1] = ‘http://www.mrbeed.com'; 

imgLink[2] = ‘http://www.mrbooks.cn/listsepbook-sepprice.html'; 

var imgLinkTitle = new Array: // 图 片 链接 提示 文字 


] 
imgLinkTitle[2] = 优惠 购书 '; 
</script> 
<script language="javascript" sre=" {util->baseUrl} /js/lzhSerollimg:js"></script> 


看 设计 过 程 
(1) 在 index.phtml 模板 页 中 ， 定 义 JavaScript 脚本 ,定义 广告 位 的 各 种 参数 并 且 载 入 调用 的 js 脚本 。 其 代 
码 请 参考 关键 技术 中 的 内 容 。 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 


让 (isset($_SESSION["unc"]) &é& $_SESSION["unc"] = "") { 
unset($_SESSION["une"]): 


3 1/ 销毁 原来 登录 用 户 的 登录 昵称 
session_register("unc"); // 注 册 新 的 用 户 昵称 到 SESSION 变量 
$_SESSION["une"] = trim($_ POST["usemc"]): 
让 (isset($_SESSION[toUrl]D) { /获取 要 跳 转 的 页 面 ， 并 进行 跳 转 
echo "<script>window .location href=" . Sutil->baseUrlO . "/" .$_SESSION[toUd] . ™;</seript>"; 
}else{ 


echo "<script>window .location href=" . Sutil->bascUrlO . "/regsuccess html';</script>"; 
则 

} else{ 
echo "<seript>alert( 注 册 失败 ， 请 重 试 ! )</script>": 


}else{ 
echo "<script>alert(' 该 昵称 已 经 被 他 人 注册 ! ")</script>"; 
} 
} 
Ssmarty->display('getuserinfo.phtml"): 
require_once ‘footer.php'; 


国 秘笈 心 ; 


心 法 领悟 594: 防止 用 户 越过 表单 限制 上 传 数据 。 

在 本 实例 的 getuserinfo .php 文件 中 , 为 了 避免 由 于 用 户 的 浏览 器 禁用 JavaScript 脚本 功能 而 使 用 户 输入 昵称 
的 唯一 性 验证 失效 ， 或 者 某 些 用 户 越过 表单 的 验证 机 制 直接 上 传 数据 ， 在 保存 用 户 提交 的 注册 信息 前 ， 首 先 使 
用 数据 库 管理 类 的 executeSQLO 方 法 查询 是 否 存在 和 用 户 提交 昵称 相同 的 注册 用 户 ， 如 果 存 在 则 提示 该 昵称 已 
被 占用 ， 并 返回 注册 页 面 要 求 用 户 重新 填写 注册 信息 ， 反 之 则 将 用 户 提交 的 注册 信息 保存 到 数据 库 中 。 


力 实例 说 明 


用 户 在 明日 科技 图 书 网 购买 图 书 时 , 需要 首先 登录 | Ou 
站 点 ,这 样 可 以 记录 购买 人 信息 ,并且 可 在 用 户 中 心 的 二 rns 
订单 查询 模块 中 查询 到 该 用 户 的 所 有 订单 信息 。 明日 科 ee ame emt | 
技 图 书 网 的 用 户 登 录 页 面 如 图 15.20 所 示 。 es rm | 


ER 要 中 


关键 技术 15.20 用户 登 录 页 面 


登录 的 目的 就 是 为 用 户 开 据 一 张 通行 证 ， 使 其 可 以 在 网 站 中 进行 任意 操作 (权限 范围 之 内 ) ， 也 是 其 行使 
网 站 会 员 权 限 的 依据 。 而 这 个 通行 证 的 开 据 应 用 的 是 SESSION 技术 。 登 录 成 功 后 ， 将 用 户 名 存储 到 SESSION 
变量 中 ， 即 完成 通行 证 的 开 据 ， 其 代码 如 下 : 
$_SESSION[unc] = $useme: 
< 仙 注 意 : 在 应 用 SESSION 变量 之 前 , 切记 一 定 要 应 用 session_start0 函 数 初始 化 SESSION 变量 ， 否 则 SESSION 
变量 不 能 使 用 ,并 且 在 应 用 session_ start0 函 数 之 前 不 能 有 任何 输出 。 本 实例 中 SESSION 变量 的 初始 
化 操作 是 在 包含 文件 1zh.inc.php 中 完成 的 。 


该 功能 利用 SESSION 可 以 在 页 面 之 间 传 递 数据 的 特性 ， 确 保 这 个 通行 证 在 网 站 的 任意 一 个 页 面 中 都 有 效 ， 
直到 用 户 退 出 登录 。 


第 15 章 ”综合 应 用 
图 设计 过 程 
(1) 在 views 文件 夹 下 创建 login.phtml 登录 表单 的 UI 界面 ， 其 实现 方法 与 注册 表单 类 似 ， 这 里 不 再 次 述 。 


(2) 当 用 户 单 击 “ 登 录 ” 按 钮 后 ， 将 对 用 户 输入 的 用 户 名 、 密 码 和 验证 码 进 行 有 效 性 验证 ， 如 果 验 证 通过 
则 将 用 户 输入 的 数据 提交 到 login php 中 进行 处 理 ， 关 键 代码 如 下 : 
<Iphp 


让 (isset($_ POST[usemc]) && $_ POST[usemc] (=") { // 判 断 是 否 提交 了 表单 
$usernc =trim($ POST[usemc]): /获得 提交 的 用 户 名 
$pwd=trim($ POST[usempwd]): // 获 得 提交 的 登录 密码 
Suser = $adminDB->executeSQL("select id, userne from tb_user where usemc=" . Suseme . " and pwd=" . md5($pwd) . "", $connID); // 按 用 户 名 
和 密码 查询 用 户 
if(! $user) { 
SerrorMsg =' 用 户 名 或 密码 输入 有 误 ! '; 
}else{ 
if(isset($_SESSION["une"])) { /销毁 原 登录 用 户 信息 ， 并 注册 新 登录 用 户 信息 给 SESSION 变量 
Session_unregister(unc'); 


} 
$ SESSION[f'unc'] = $userme; 
@$adminDB->executeSQL("update tb_user set logintimes=logintimes+1 ,lastlogintime =" . date('Y-m-d H:i:s) . ",ip=" . 
$_SERVER[REMOTE_ADDR'] .™" where usemc=" .$_ SESSION[unc] ."", $connID); /更 改 用 户 的 登录 信息 
if(isset($ SESSIONTYoUrlTD) { 
echo "<script>window ,location href=" . Sutil->baseUrlO . "/" .$_SESSION[YoUd] .";</seript>"; 


echo "<script>window location href=" . Sutil->baseUrlO . "/usercenter.html';</script>"; 
exitO; 


} 
人 S$errorMsg); 
Ssmarty->display(login.phtml9; 
require_once ‘footer.php'; 
上 述 代码 中 ， 首 先 定义 变量 gerrorMsg， 保 存 处 理 登 录 表 单 提交 数据 时 出 现 的 错误 信息 〈 例 如 登录 失败 信息 
等 ) ， 然 后 使 用 $_POST 全 局 数组 接收 用 户 提交 的 用 户 名 和 登录 密码 ， 并 使 用 数据 库 管理 类 的 executeSQL( 方 法 
执行 查询 语句 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 更 改 用 户 登 录 次 数 和 最 后 登录 时 间 ， 反 之 


则 将 登录 失败 信息 赋 给 变量 gerrorMsg， 并 传递 给 login.phtml 模板 。 
秘笈 心 法 


心 法 领悟 595: 延长 SESSION 的 生命 周期 。 

在 开发 程序 的 过 程 中 可 能 会 遇 到 这 样 的 情况 ， 以 会 员 的 身份 登录 一 个 网 站 后 ， 如 停留 的 时 间 较 长 ， 此 时 在 
这 个 网 站 中 发 布 信息 时 ， 会 提示 “您 没有 登录 ， 请 登录 后 再 发 布 信息 ”。 

之 所 以 出 现 此 类 问题 ， 就 是 因为 在 登录 时 定义 的 SESSION 变量 已 经 过 期 ， 导 致 当前 用 户 不 可 用 ， 需 要 重新 
登录 。 解 决 这 个 问题 最 好 的 方法 就 是 通过 session_set_cookie_params0 函 数 延 长 SESSION 的 生命 周期 , 将 过 期 时 
间 设 置 为 0。 


A 高 级 | 
实例 596 趣味 指数 : 相机 本 办 | 
实例 说 明 


明日 科技 图 书 网 的 用 户 中 心 ， 主 要 用 于 实现 对 用 户 注册 信息 和 用 户 登 录 密码 的 修改 、 用 户 订单 的 查询 和 意 
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本 框 、 新 密码 录入 文本 框 和 确认 密码 录入 文本 框 3 个 表单 元 素 ， 如 图 15.22 所 示 。 
系统 将 用 户 修改 的 数据 提交 到 usercenterchangepwd.php 页 面 ， 在 该 页 面 中 完成 对 密码 的 更 改 。 首 先 判断 用 
户 是 否 非法 登录 ， 然 后 判断 用 户 输入 的 原 密码 是 否 正 确 ， 如 果 正 确 则 将 用 户 密码 更 改 成 新 值 ， 反 之 给 出 错误 提 


示 ， 其 代码 如 下 : 

<?php 

require_once ‘header.php'; 

if(! isset($_SESSION['une']) 1 $_SESSION[unc] 一 "){ // 判 断 用 户 是 否 已 经 登录 
echo "<script>alert( 禁止 非 登 录 ! ");window.location href=". Sutil->baseUrlO . "/index.html';</script>"; 
exit0; 

} 

让 (isset($_ POST[oldpwd]) && $_POST['oldpwd] =") { // 判 断 用 户 是 否 已 经 提交 了 表单 
证 (! $adminDB->executeSQL("select id, useme from tb_user where useme=" .$_SESSION[unc] . " and pwd=" .mds($_ POST[oldpwd]) .™", 

E00 . 

echo "<script>alert(' 原 密码 输入 有 误 ! ");</script>"; // 验 证 原 密 码 是 否 正确 


} else{ 
ff ($adminDB->executeSQL("update tb_user set pwd=" .mds($_ POST[pwdl]) . ". truepwd=" .$_ POST[pwdl] . " where usernc=" . 
$_SESSION['unc'] . ™", $connID)) { // 执 行 更 改 密码 操作 
echo "<script>alert(' 密 码 更 改 成 功 ! ");</script>"; 
jelse{ 
echo "<script>alert(' 密 码 更 改 失败 ! ");</script>"; 
} 
} 


Cn 
require_once ‘footer.php’; 
(3) 意见 反馈 。 

用 户 在 参与 本 站 活动 时 ， 如 果 对 网 站 的 管理 或 运营 存在 建议 或 意见 ， 可 以 通过 用 户 中 心 的 意见 反馈 模块 将 
个 人 意见 提交 给 网 站 管理 者 。 明 日 科技 图 书 网 的 意见 反馈 表单 如 图 15.23 所 示 。 
ec 
ME: 2 Pt 并 且 记 用 FHF 化 焰 名 
新 神思 | 对 您 使 用 的 拉 术 间 常 隔 兴 施 ， 芒 所 和 不 训 唱 


对 ER | 


| EE 加 | EE PO i 
图 15.22 用 户 密码 修改 表单 图 15.23 用 户 意见 反馈 表单 


用 户 填写 的 反馈 意见 将 被 提交 到 userfeedback.php 页 面 ， 在 该 页 面 中 应 用 数据 库 管理 类 中 的 executeSQLO 
方法 将 反馈 意见 添加 到 tb_feedback 数据 表 中 ， 其 代码 如 下 : 


if(! isset($_SESSION['unc']) | $_SESSION[une] —") { // 判 断 用 户 是 否 已 经 登录 

echo "<script>alert(' 禁 止 非 登 录 ! '):window.location.href=" . Sutil->baseUrlO . "/index.html';</script>"; 

exit0: 
} 
if(isset($_POST['title']) && $_POST['title] =") { a 

if (SadminDB->executeSQL("insert into tb_feedback(title. eontent, addtime useme) values(" . $_POST['title] . ". ". $_POST[eontent] . ", " . 
date(Y-m-d Hii's) . ". " . $_SESSION['une'] . ")", $connID)) { /保存 用 户 的 反馈 意见 信息 

echo "<script>alert( 你 的 反馈 信息 已 经 成 功 保存 ， 谢谢 您 的 支持 ! ");</script>"; 
}else{ 


echo "<script>alert( 反 馈 信息 保存 失败 ， 请 重 试 ! );</script>"; 
2. 
} 


力 秘笈 心 法 


心 法 领悟 596: 用 户 中心 功 能 总 结 。 

在 用 户 中 心 功能 模块 中 应 用 的 技术 可 以 划分 为 两 部 分 : 第 一 部 分 ， 在 Smarty 模板 页 中 创建 form 表单 ， 提 
交 用 户 需 要 更 新 的 数据 ; 第 二 部 分 , 在 PHP 动态 页 中 , 应 用 数据 库 管理 类 中 的 executeSQLO 方 法 执行 select\insert 
和 update 语句 ， 完 成 对 用 户 的 验证 、 数 据 的 添加 和 更 新 操作 。 
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// 如 果 变 量 orderno 的 值 不 为 空 ， 并 且 变 量 def 的 值 不 等 于 qx， 则 执行 查询 语句 ， 计 算出 订单 的 详细 信息 ， 并 且 将 查询 结果 赋 给 模板 变量 
让 (isset($_GET[ordemo]) && $_GET['ordemo']!=" && $_GET['def] (=qx){ 
Sorder = $adminDB->executeSQL("select id, ordemo. usemame, address, sex, yb, tel, idstr, numstr, rectype, paytype, goodsprice, yjprice, totalprice, 
addtime, isfk, isfh, issh from tb_order where ordermno= "trim($_GET[ordemo])."". $connID); 
Sarraylds = explode('@', Sorderfol[idstr]): 
SarrayNums = explode('@', Sorder[ol[numstr]): 
SarrayCarInfos = array(): 
S$totalPrice = 0; 
for($i= 0; Si < count(SarrayIds): $i++){ 
Sbookid = $arrayIds[$i]; 
if($bookid (= "){ 
StmpArray = array(); 
Sbookinfo = $adminDB->executeSQL("select id, bookname ,oldprice, newprice from tb_bookinfo where id=".$bookid."", $connID); 
StmpArray['id'] = $bookinfo[O]['id]; 
StmpArray[ bookname'] = $bookinfo[0][bookname']; 
StmpArray['oldprice'] = $bookinfo[O]['oldprice]; 
StmpArray['newprice'] = $bookinfo[0]['newprice']; 
StmpArray[mum'] = $arrayNums[$i]; 
S$tmpArray['smaliTotalPrice'] = Sbookinfo[0][mewprice'] * $arrayNums[$i]: 
StotalPrice += $tmpArray['smallTotalPrice] 
armray_push($arrayCarInfos, $tmpArray): 


} 


} 
$smarty->assign(arrayCarInfos'\ $arrayCarInfos); 
$smarty->assign('order’, Sorder): 
SisShow = T'; 
} 
Ssmarty->assign('isShow', $isShow); 
// 执 行 查询 操作 ， 输 出 当前 用 户 的 订单 信息 
Sorders = $adminDB->executeSQL("select ordemo, addtime, usemame, totalprice from tb_order where orderusemc=".$_SESSION["unc']." and isqx=0", 
SconnID); 


Ssmarty->assign('‘orders', $orders); // 将 查询 结果 赋 给 模板 变量 
S$smarty->display('‘usercenterorder.phtml); // 指 定 模 板 页 
require_once ‘footer.php'; // 包 含 网 站 的 尾 文件 


(2) 在 views 文件 夹 下 创建 usercenterorder.phtml 模板 文件 ， 根 据 模板 变量 中 传递 的 数据 完成 “我 的 订单 ” 
模块 页 面 的 设计 。 首 先 ， 通 过 section 语句 循环 输出 当前 用 户 的 订单 信息 并 创建 “查看 ” 超 链 接 链 接 到 本 页 ， 将 
订单 号 作为 参数 进行 传递 。 然 后 ， 应 用 站 语句 判断 当 模 板 变量 $isShow 的 值 为 工时， 输出 模板 变量 中 传递 的 订 
单 详细 信息 。 最 后 ， 创 建 “ 取 消 订购 ”和 “确认 收 货 ”按钮 ， 通 过 onclick 事件 调用 JavaScript 完成 对 订单 的 处 
理 操 作 ， 其 关键 代码 如 下 : 


{section name=oID loop=$orders} 
<div style="width:90%; height:20px; border-bottom:1px solid #0C92AB; border-left:1px solid #0C92AB; border-right:1px solid #0C92AB; 
padding-top:3px"> 
<li style="display:inline; width:26%: float:left; border-right:1px solid #0C92AB">{$orders[oID].orderno} </li> 
<li style="display:inline: width:2296: float:left; border-right: lpx solid #0C92AB">{$orders[oID].usemame} </li> 
<li style="display:inline; width:22%; float:left; border-right: px solid #0C92AB"> {util->moneyFormat p=$orders[oID].totalprice} </li> 
<li style="display:inline; width:2296: float:left: border-right: px solid #0C92AB">{$orders[oID].addtime}</li> 
li style="display:inline: width:896: float:left"><a href=" {util->baseUrl}/usercenterorder-{$orders[oID].ordemo} html class="al"> 查 看 </a></li> 
</div> 
{/section} 
{if $isShow — T'} 
<div style="width:680px: border-top:1px dotted #CCCCCC: border-bottom: px dotted #CCCCCC: padding:15px"> 
<div style="width:630px: height:22px: text-align:left padding-top:Spx"> 
<li style="display:inline: width:200px: height:22px: background-color:#006D84: padding-top:5px: padding-left:10px:; color:-#FFFFFF: 
float:left"> <strong> 订 单 号 : {$order[0].ordemo}</strong></li> 
<li style="display:inline: width:200px; height:22px: padding-top:5px; float:right"> 订 购 时 间 : {Sorder[0].addtime}</li> 
</div> 
<!-- 省 略 了 部 分 代码 -> 
<div style="width:680px: height:30px: padding-top:3px; text-align:left"><strong> 订购 状态 </strong>&nbsp:&nbsp:&nbsp:[&nbsp: 已 收 款 : 
<input type="checkbox" disabled {if $order[0].isfk 一 1 }checked{/if} 广 &nbsp:&nbsp: 已 发 货 : 
<input type="checkbox" disabled {if $order[0].isth 一 1 }checked{/i@/> 已 收 货 : 
<input type="checkbox" disabled {if $order[O] issh 一 1 }checked{/if} />&nbsp:] 
<input type="button" value=" 取 消 订购 " {if Sorder[0]issh 一 1 || Sorder[0] is 全 一 1 || Sorderfo] isfh 一 1 }disabled{/if} 
onclick="javascript:if(window.confirm(' 您 确认 取消 该 订单 吗 ? )==true) {ldelim}windowlocation href='usercenterorder-{$order[0].ordermo} 
-qxhtml';{rdelim}"/> 
<input type="button" value=" 确 认 收 货 " onclick="javascript:if(window.confirm(' 您 确认 已 经 收 货 了 吗 ? ) 一 tue)fldelim} 
‘window.location href='usercenterorder- {Sorder[0].ordermo}-y.html'; {rdelim}" fifSorderfo]issh 一 1 }disabled{/if}/> 
</div> 


847 


PHP 开发 实例 大 全 (基础 卷 ) 


<div> 
MW 


心 法 领悟 597: 实现 退出 登录 功能 。 

用 户 在 登录 成 功 后 ， 可 以 修改 注册 信息 、 登 录 密码 ， 查 看 订单 信息 和 提交 意见 反馈 等 ， 那 么 如 何 实现 退出 
登录 呢 ? 

实现 退出 登录 功能 应 用 的 是 session start()、session_unregister() .unset0 和 header() 函 数 。 首 先 初 始 化 SESSION 
变量 , 然后 注销 SESSION 变量 unc, 接着 删除 SESSION 变量 ,最 后 跳 转 到 index.html 页 面 , 该 功能 存储 于 logout php 
文件 中 。 


力 实例 说 明 


在 明日 科技 图 书 网 的 用 户 登 录 页 面 中 ， 有 一 个 “ 找 回 密码 ” 
超 链 接 ， 单 击 该 链接 将 执行 密码 找 回 的 操作 。 第 一 步 : 输入 用 
户 的 昵称 ;第 二 步 : 输入 密码 提示 答案 ; 第 三 步 : 如 果 输 入 答 
案 不 正确 ， 则 给 出 错误 提示 信息 ， 否 则 弹出 密码 找 回 成 功 对 话 
框 并 且 显 示 原 密码 ， 也 可 以 选择 重新 设置 密码 ， 其 运行 效果 如 


图 15.25 所 示 。 me 
图 关键 技术 二 一 


在 找 回 密码 功能 实现 过 程 中 ， 应 用 到 的 技术 如 下 ; 9 入 加 闪 各 的 报信 活 各 
(1) 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 实 现 直接 在 Smarty 模板 页 
中 定义 JavaScript。 
(2) 应 用 window 对 象 中 的 open() 方 法 打开 openfindpwd.php 文件 ， 开 始 执行 找 回 密码 的 操作 。 
(3) 应 用 PHP 中 提供 的 MySQL 数据 库 函 数 操作 MySQL 数据 库 ， 完 成 找 回 密码 、 更 改 密码 的 操作 。 其 中 ， 
首先 在 conn.php 文件 中 应 用 mysql_connectO、mysql select db0 和 mysql_query0 函 数 完 成 与 数据 库 服务 器 、 数 据 
库 的 连接 ， 并 且 设 置 编码 格式 ， 其 代码 如 下 : 


<?php 

$conn=mysql_connect("localhost", "root”,"111"); // 连 接 数 据 库 服务 器 
mysql_select_db("db_database15",$conn): /连接 数据 库 
mysql_query("set names gb2312"): /设置 数据 库 编码 格式 
?> 


图 设计 过 程 
(1) 在 模板 页 login.phtml 中 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 直接 编写 JavaScript 脚本 方法 


openfindpwd0， 打 开 openfindpwd.php 文件 ， 其 关键 代码 如 下 : 
<script language="JavaScript" type="text/iavascript"> 
function op 
{ldelim} 
window.open("openfindpwd.php"."newframe"."lefi=200.top=200,width=200.height=100.menubar=no.toolbar=no.location=no.scrollbars=no,location=no 
");{rdelim} 
‘</script> 
<a href="javascript:openfindpwd0O" class="al">[ 找 会 密码 ]</a> 


(2) 新 建 openfindpwd.php 文件 ， 创 建 form 表单 ， 提 交 要 找 回 密码 的 用 户 的 昵称 ， 并 且 通 过 JavaScript 脚 
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本 判断 用 户 提交 的 数据 是 否 为 空 ， 将 数据 提交 到 findpwd.php 页 面 。 

(3) 新 建 findpwd.php 文件 。 首 先 包 含 数据 库 连接 文件 conn.php， 然 后 判断 用 户 提交 的 昵称 在 数据 库 中 是 
否 存在 ， 如 果 存 在 则 输出 此 用 户 注册 时 填写 的 密码 提示 问题 ， 并 且 通 过 form 表单 将 问题 的 答案 提交 到 
showpwd.php 文件 中 进行 处 理 。 

(4) 新 建 showpwd.php 文件 ,首先 包含 数据 库 的 连接 文件 conn.php， 然后 判断 用 户 提交 的 问题 答案 是 否 正 
确 ， 如 果 不 正确 则 给 出 提示 信息 并 跳 转 到 上 一 页 ， 如 果 正 确 则 输出 显示 原 密码 和 重 设 密码 的 超 链接 。 

(5) 新 建 changepwd.php 文件 , 创建 重新 设置 密码 的 form 表单 , 将 重新 设置 的 密码 提交 到 savechangepwd. 
php 文件 中 。 

(6) 新 建 savechangepwd.php 文件 ， 完 成 用 户 密码 的 更 新 ， 其 代码 如 下 : 


<?php 

include_once ("conn php"); // 连 接 数据 库 
Struepwd =$_POST[userpwd1]: /获取 提交 的 新 密码 
Spwd = md5($truepwd); // 对 密码 进行 md5 加 密 


if (mysql_query("update tb_user set pwd='$pwd',truepwd='$truepwd' where id=" . $_POST["userid"] . "", $conn)) { // 执 行 更 新 操作 
echo "<script>alert(' 密 码 更 改 成 功 !");history.back(;</script>"; 

yelse{ 

echo "<script>alert( 密 码 更 改 失败 !):history.back0;</script>"; 


} 
mysql_close($conn): /关闭 数据 库 连接 
> 


图 秘笈 心 法 

心 法 领悟 598: MySQL 数据 库 函数 。 

在 明日 科技 图 书 网 站 项 目 中 , 为 了 体现 本 章 内 容 的 综合 性 ， 不 但 应 用 Smarty 模板 和 ADODB 类 库 技术 ， 同 
时 也 融入 了 MySQL 函数 操作 MySQL 数据 库 的 方法 。 有 关 通 过 MySQL 函数 操作 MySQL 数据 库 的 详细 讲解 可 
以 参考 第 8 章 的 内 容 。 


15.4 数据 的 输出 


本 节 将 介绍 数据 输出 功能 的 实现 ， 包 括 图 书 导航 、 图 书 分 类 、 特 别 图 书 、 图 书 试 读 、 图 书 详细 信息 和 新 闻 
公告 等 功能 。 
高 级 
实 斧 
实例 599 趣味 指数 : 相机 本 宙 


| 
| 
上 
| 


| | 实例 说 明 当前 邱 肌 : 全 六 图 书 各 所 
明日 科技 图 书 网 站 中 ， 通 过 图 书 导航 功能 展示 出 网 站 中 图 书 的 所 有 类 别 ， 并 且 : i 
将 图 书 划 分 为 初级 、 中 级 和 高 级 3 种 类 型 ,图书 导航 功能 的 运行 效果 如 图 15.26 所 示 。 
力 关键 技术 
图 15.26 图 书 导航 功能 
实现 图 书 导 航 功 能 应 用 的 关键 技术 如 下 : 


(1) 在 index.php 动态 页 中 ， 应 用 数据 库 管理 类 中 的 executeSQL0 方 法 查询 出 图 书 大 类 和 小 类 数据 表 中 的 
数据 。 其 中 关于 数据 库 的 连接 和 操作 方法 可 以 参考 本 章 实例 586 和 实例 587。 

(2) 在 index.phtml 模板 页 中 ， 应 用 Smarty 模板 中 的 站 语句 根据 模板 变量 传递 的 值 判 断 应 具体 输出 哪 种 类 
型 的 数据 ， 然 后 应 用 section 语句 进行 嵌 套 ， 完 成 图 书 大 类 与 小 类 的 对 应 循环 输出 。 
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以 分 页 的 形式 展现 出 来 。 明 日 科技 图 书 网 图 书 分 类 展示 效果 如 图 15.27 所 示 。 


3 上 尝 时 间 1 出 新 问 上 优 术 全 丙 | 让 六 类 由 到 少 
图 书 小 类 

“| 全 部 | ?XI | 要 丙 少 各 | 再 姑 导 各 小 
二/ 共 1 页 。 兰 页 上 -页 下 -页 尼 页 


图 15.27 明日 科技 图 书 网 图 书 分 类 展示 效果 


力 关键 技术 


实现 图 书 分 类 展示 的 关键 是 数据 表 的 创建 , 在 图 书 大 类 表 tb_bigtype 和 图 书 小 类 表 tb_smalltype 之 间 存 在 一 
个 关联 的 字段 ， 通 过 该 字段 确立 两 个 表 中 数据 的 从 属 关系 。 这 里 将 tb_bigtype 表 中 的 id 字段 与 tb_smalltype 表 
中 的 bigtypeid 字段 建立 关联 ， 即 在 tb_smalltype 表 中 ， 根 据 字 段 bigtypeid 的 值 可 以 确定 该 小 类 属于 哪个 大 类 。 
图 设计 过 程 

在 图 书 分 类 展示 页 面 中 ， 浏 览 者 可 以 从 最 上 面 的 图 书 大 类 中 选择 要 购买 图 书 的 大 类 ， 然 后 在 子 类 中 选择 具 
体 的 语言 类 别 ， 这 样 就 可 以 将 指定 语言 类 别 的 图 书展 示 出 来 ， 同 时 可 以 按照 指定 的 排列 方式 和 图 书 层次 对 图 书 
的 显示 顺序 进行 调整 。 具 体 实现 过 程 如 下 : 

(1) 在 listbook.php 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 传递 到 页 面 的 排序 方式 标识 、 图 书 层次 标识 和 


当前 页 显示 的 页 码 ， 然 后 使 用 分 页 类 的 pageData0 方 法 获取 分 页 参数 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 
if(! isset($. Type 了 ||$_GET[pltype] —") { /[ 获 得 图 书 排列 方式 
Vast 
Spltype = $_GET['pltype']: 


S$smarty->assign('pltype', $pltype); 

if(! isset($_GET['cctype']) || $_GET['cctype] —") { // 获 得 图 书 层次 标识 
Sectype ='1'; 

yelse{ 
S$cctype = $_GET['cctype']: 

} 

S$smarty->assign('cctype', $cctype): 

if (lisset($_GET['page']) || $_GET['page] —") { // 获 得 当前 要 显示 的 页 码 
Spage ='1'; 

}else{ 
Spage =$ GET['page'l: 


S$smarty->assign('page', Spage): 
$smalltype = $adminDB->executeSQL("select id, bigtypeid. typename from tb_smalltype where id='$stid™", $connID): // 查 询 图 书 小 类 
Ssmarty->assign('smalltype', $smalltype); 
Sbigtype = $adminDB->executeSQL("select id. typename from tb_bigtype where id=" . Ssmalltype[0][bigtypeid] . "". $connID); 
S$smarty->assign(bigtype' $bigtype); 
$smalltypes = $adminDB->executeSQL("select id, typename from tb_smalltype where bigtypeid=" . Sbigtype[o]['id] . "", $connID); /查询 图 书 大 类 
Ssmarty->assign('smalltypes', $smalltypes); 
证 人 1){ // 设 置 图 书 层次 条 件 
=" and smalltypeid =" . $stid . ™"; 

} es 20{ 

Swhere =" and bookce = 1 and smalltypeid =" . $stid . "": 
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} elseif ($cctype — 30 { 
Swhere =" and bookcc=2 and smalltypeid =". $stid . ™"; 
} elseif ($cctype — '4) { 
Swhere =" and bookcc=3 and smalltypeid =" . $stid . ™"; 
} 


if($pltype —'1) { // 设 置 图 书 排列 方式 
Sorder = "addtime dese"; 
} 和 pe | 
= "pubtime dese"; 
} sae (pipe —3) { 
Sorder = "newprice ase"; 
} elseif (Spltype — 4) { 
Sorder = "browsertime dese"; 


} 
$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo.oldprice. tb_bookinfo.newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
tb1 bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime, tb | bookinfo.addtime, tb bookinfo .ishave, tb_pub.pubname from tb_bookinfo, tb_pub 
where tb_bookinfo.pubid = tb_pub.id " . $where . " order by " . $order . " // 构 建 查询 语句 
$bookinfos = $pageDB->pageData($sql, $connID, 10. $page); /执行 分 页 查询 
Samarty->assign(bookinfos' $bookinfos); 
(2) 在 views\listbook.phtml 模板 页 中 ， 应 用 section 语句 完成 指定 类 别 图 书信 息 的 分 页 显示 ， 关 键 代码 如 下 : 
{if $bookinfos.countRs > 0} 
I 
<div style="width:930px"> 
<br> 
<div style="width:100%%:; height:180px"> 
<div style="width:20%; height:100%; float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html"><img sre="{$system[01.bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:7896: height:100%; float:right; text-align:left: font-size:13px"> 
<li style="display:inline"><a href=" {util->baseUr}/bookinfo- {$bookinfos.data[pbID].id} html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 ，{$bookinfos.data[pbID].pubname} </li> 
<br><br> 

<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 
<br><br> 


<li style="display:inline"> 上 架 时 间 : {$bookinfos.data[pbID].addtimeltruncate:10:"}&nbsp;&nbsp; 出 版 时 间 : 
{$bookinfos.data[pbID].pubtimeltruncate:10:"} &nbsp;&nbsp; 浏 览 次 数 ， {$bookinfos.data[pbID].browsertime} &nbsp; 次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 :<img sre=" {util->baseUrl}/img/mark_green.gif" />&nbsp:<s>{util->moneyFormat 
p=$bookinfos.data[pbID].oldprice} </s>&nbsp;&enbsp;<font color="#FF0000"> 会 员 价 : <img sre=" {util->baseUrl}/img/mark_red.gif 
/>&enbsp; {util->moneyFormat p=$bookinfos.data[pbID].newprice} </font> 
</li> 
<br><br> 
li style="display:inline"><a href=" {util->baseUrl} /cart- {$bookinfos.data[pbID].id}-add.html"><img sre=" {util->baseUrl}/ 
imgybutton_order.gif' border="0"/></a>é&nbsp:<a href=" {util->baseUrl} /bookinfo-{$bookinfos.data[pbID].id} html"><img sre=" {util->baseUrl} /img/ 
button_info gif' border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:50px: border:1px solid #CCCCCC: text-align:left; line-height:18px: color:#990000; padding: Spx"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px; height:80px; font-size:14px; color:#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif"><br /> 
<strong> 对 不 起 ， 暂 无 该 类 图 书 ! </strong> 


</div> 
他 
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心 法 领悟 600: 为 什么 编辑 的 模板 页 文件 后 缀 是 .phtml， 而 输出 时 文件 的 后 缀 是 .html。 
因为 本 实例 的 开发 应 用 PHP 伪 静 态 技术 ,会 对 输出 文件 的 后 级 和 传递 的 参数 进行 重新 定义 。 伪 静态 技术 的 


执行 要 通过 .htaccess 文件 。 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 设计 过 程 
(1) 建立 listsepbook.php 文件 用 来 实现 业务 逻辑 。 在 该 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 查询 字符 串 
参数 t 的 值 ， 然 后 根据 该 值 决 定 当前 页 面 要 显示 的 内 容 并 构建 查询 语句 ， 最 后 使 用 分 页 类 的 pageData() 方 法 实现 


分 页 查询 ， 其 完整 代码 请 参考 本 书 光盘 ， 这 里 不 再 歼 述 。 
(2) 建立 模板 页 listsepbook.phtml， 通 过 section 语句 分 页 输出 指定 类 别 下 的 图 书信 息 ， 其 关键 代码 如 下 : 


{if$bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930ps"> 
<br> 
<div style="width:100%; height:180px"> 
<div style="width:20%; height:10096: float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"><img sre="{$system[0].bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:78%%; height:10096: float:right; text-align:left; font-size:13px"> 
<li style="display:inline"><a href="{util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 ，{$bookinfos.data[pbID].pubname}</li> 
<br><br> 

<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 
<br><br> 


<li style="display:inline"> 上 架 时 间 : {$bookinfos.data[pbID].addtimeltruncate:10:""}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 出 版 时 
间 : {$bookinfos.data[pbID].pubtimeltruncate:10:"}&nbsp;é&nbsp;&nbsp;&nbsp;&nbsp;&nbsp: 浏 览 次 数 : {$bookinfos.data[pbID].browsertime}&nbsp; 
次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 ，<img sre=" {util->baseUrl}/img/mark_green.gif' />&nbsp:<s>futil->moncyFormat 
p=S$bookinfos.data[pbID].oldprice}</s>&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbspi&nbspi&nbspi&nbsp: 
<font color="#FF0000"> 会 员 价 :<img sre="{util->baseUd}/img/mark_red.gif" />&nbsp; {util->moneyFormat 
p=$bookinfos.data[pbID].newprice} </font> 
</li> 
<br><br> 
<li style="display:inline"><a href=" {util->baseUrl} /cart-{$bookinfos.data[pbID].id}-add.html"><img 
sre=" {util->baseUrl} /img/button_order.gif” border="0"/></a>&nbsp:&nbsp:&nbsp:&nbsp:<a 
href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"><img sre=" {util->baseUrl}/img/button_info.gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:SOpx: border: 1px solid #CCCCCC; text-align:left: line-height18px: color:#990000; padding:Spx"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px; height:80px; font-size:14px: color:#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif’><br /> 
<strong> 对 不 起 ， 暂 无 新 书信 息 ! </strong> 
</div> 
UD 
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心 法 领悟 601: SQL 语句 中 的 多 表 查 询 。 

在 SQL 语言 中 ， 通 过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 用 “表明 .字段 名 ”表示 ， 这 样 可 以 避免 
因 表 之 间 字 段 重 名 而 无 法 获知 该 字段 属于 哪个 表 。 在 where 子 句 中 多 个 表 之 间 所 形成 的 联动 关系 应 按 如 下 格式 
区 1 字段 - 表 字段 and 其 他 查询 条 件 

多 表 查 询 的 语法 如 下 : 

sleet 字段 名 fom 表 1 表 2.。where 表 工 字段 - 表 2 字段 and 其 他 查询 条 件 


第 15 章 ”综合 应 用 


趣味 指数 ， 请 请 坪 家 | 


力 实例 说 明 
为 了 能 够 让 读者 了 解 某 本 图 书 的 大 概 内 容 ， 吸 引 更 多 读者 购买 图 书 ， 在 制作 明日 科技 图 书 网 时 ， 将 图 书 斌 


读 作为 单独 模块 ， 其 运行 效果 如 
长 可 而 明日 和 扩 书 店 


Wwwrmrpooks-em 


图 15.29 所 示 。 


其 书 


黄页 要 书 将 从 。 热卖 


冤 当 前 的 位 置 ， 明 电网 上书 居 27 国 书 区 该 下 过 
于吉 共事 全 而 10 可 第 1 页 /其 1 页 。 首页 上 一 页 下 一 页 尾 责 


Ch 开发 二 验 技 巧 宝 并》 


二 有 人 组 了 1009 人 关于 Wisaal Ph 开发 的 和 台大 了 提亲 开发 中 的 各 和 袜 际 大 求 。 全 世 分 广 2 全， 分 虽 杂 河 训 基础 匡 大 型 ， 开 发 环 次 ，NB 尖 几 技 本 ， 玉 人 
tte rte the git au tre holon oh Hy 
Tleroet 网 机、ATL Cen 村、 所 本 六 RUB: 宁 引 


ET 本 本 0 本 第 ! 页 / 失 /页 。 商 页 上 -本 下 一 页 四 再 


图 15.29 ” 试 读 图 书展 示 


图 关键 技术 


实现 图 书 试 读 的 关键 技术 是 如 何 获取 到 试 读 文 件 ， 本 实例 中 应 用 HTTP 方式 完成 试 读 文件 的 下 载 操作 ， 其 
中 关键 是 header0 函 数 的 应 用 。 有 关 应 用 HTTP 方式 进行 下 载 的 详细 讲解 请 参考 本 书 第 4 章 的 内 容 。 
在 本 项 目 中 ， 下 载 的 操作 在 upfiles\doc\download.php 文件 中 完成 ， 同 时 还 对 文件 被 下 载 的 次 数 进行 统计 ， 


其 关键 代码 如 下 
?php 
require_once "lzh.inc.php'; /包含 类 的 实例 化 文件 
$filename=$_GET['filename']; // 获 取 文件 名 称 
S$rid = $_GET['rid]; // 获 取 文 件 的 计 
S$system = $adminDB->executeSQL("update tb_read set downtimes = downtimes+l where id='$rid", $connID); /执行 更 新 操作 
这 file_exists($filename) 一 false){ 1/ 判断 上 传 文件 是 否 存 在 
echo "<script>alert( 对 不 起 ， 本 站 暂时 停止 该 文件 下 载 1):history.back0:</script>"; 
exit; 
} 
$fp=fopen($filename,"r"); 1/ 打 开 上 传 文件 
header("Content-type:application/octet-stream"); 
header("Accept-ranges:bytes"): 


header("Accept-length:".filesize($filename)): 


header("Content-Disposition:attachment:filename=".$filename):; 
echo fread($fp,filesize($filename)); // 读 取 上 传 文件 内 容 
flose($fp); 1/ 关闭 文 件 

力 设计 过 程 


图 书 试 读 模块 对 明日 科技 图 书 网 站 中 所 有 可 以 试 读 的 图 书 进行 分 页 展示 。 

(1) 新 建 listreadbook.php 文件 ， 完 成 所 有 试 读 图 书 的 分 页 查询 操作 。 首 先 通过 $_GET 全 局 数组 接收 查询 
字符 串 page 的 值 ， 该 值 用 来 指定 当前 页 面 要 显示 的 内 容 。 然 后 构建 查询 语句 ， 通 过 分 页 类 的 pageData() 方 法 获 
得 分 页 数据 。 最 后 将 查询 结果 赋 给 模板 变量 并 且 指 定 模板 页 ， 具 体 实现 代码 如 下 : 
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Tequire_once header.php'; 

Snowtype= ' 图 书 试 读 下 载 '; 

S$smarty->assign('nowtype', $nowtype); 

S$system = $adminDB->executeSQL("select bookimgurl readur] from tb_system where mark = 1", $connID); 


S$smarty->assign('system', $system); // 查 询 系统 配置 信息 

if(! isset($_GET['page']) || $_GET['page] —") { /获取 当前 页 码 
Spage ="1'; 

}else{ 


Spage =$ GETI'page'l; 


} 

$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo.oldprice, tb_bookinfo.newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
tb_bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime, tb_bookinfo.addtime, tb_bookinfo.ishave, tb_pub.pubname, tb_read.id as readid, 
tb_read filename from tb_bookinfo, tb_pub, tb_read where tb_bookinfo.pubid =tb_pub.id and tb_read.bookinfoid =tb_ bookinfoid order by 


tb_read.addtime dese"; // 构 建 查询 语句 
S$bookinfos = $pageDB->pageData($sql, $connID, 10. Spage); // 执 行 分 页 查询 
Ssmarty->assign(bookinfos' $bookinfos); 

S$smarty->display('listreadbook.phtml’); 


Tequire_once ‘footer.php'; 


(2) 新 建 模板 文件 listreadbook.phtml， 应 用 section 语句 完成 试 读 图 书 的 分 页 输出 ,创建 “ 试 读 下 载 ” 超 链 
接 ， 链 接 到 upfiles\doc\download.php 文件 ， 完 成 试 读 文 件 的 下 载 操作 ， 其 关键 代码 如 下 : 


{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 

<br> 


<div style="width:100%; height:180px"> 
<div style="width:20%; height:100%; float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.datafpbID].id} .html"><img src=" {$system[01.bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:78%; height:100%; float:right; text-align:left: font-size:13px"> 
<li style="display:inline"><a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} .html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname}</strong></a></li> 
<li style="display:inline"><a href=" {util->baseUrl}/cart- {$bookinfos.datafpbID1id}-add.html"><img sre=" {util->baseUrl}/ 
img/button_order.gif" border="0"/></a>&nbsp:&nbsp:&nbsp:&nbsp:<a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} html"><img 
sre=" {util->baseUrl}/img/button info.gif' border="0"/></a>&nbspi&nbsp:&nbsp:&nbsp;<a href="{$system[Ol.readurl}/download.php?rid= 
{$bookinfos.data[pbID].readid} &filename={$bookinfos.data[pbID] filename} "><img sre=" {util->baseUrl} /img/button_sdcz.gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:SOpx: border:1px solid #C' 
{util->unHtml p=$bookinfos .data[pbID] aboutltnuncate:420: 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px: height:80px: font-size:14px; color#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif’><br /> 
<strong> 对 不 起 ， 暂 无 试 读 图 书信 息 ! </strong> 


Citext-align:left line-height: 18px; color:#990000; padding:5pxr> 
false} 


<div> 
UD 
(3) 有 关 下 载 试 读 文 件 的 内 容 请 参考 本 实例 的 关键 代码 ， 这 里 不 再 著述 。 


力 秘笈 心 法 
心 法 领悟 602: header0 函 数 的 常用 功能 。 


header0 函 数 的 常用 功能 有 : 
(1) 重 定向 ， 这 是 最 常用 的 功能 。 
<?php 


header("Location: http://www.mrbeed.com"): 
> 


2) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 而 不 是 使 用 存在 于 客户 端的 缓存 。 
<9?] 
了 量 页 面 的 过 其 时 间 (用 格林 威 治 时 间 表示 ) 

header("Expires: Mon. 08 Jul 2008 08:08:08 GMT"): 


856 
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/设置 页 面 的 最 后 更 新 日 期 〔 用 格林 威 治 时 间 表示 ) ， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: ". gmdate("D. dM Y H:i:s") . "GMT"); 
header("Cache-Control: no-cache, must-revalidate"); // 控 制 页 面 不 使 用 缓存 


header("Pragma: no-cache"): /参数 与 以 前 的 服务 器 兼容 ， 即 兼容 HTTP 1.0 协议 
header("Content-type: application/file"); /输出 类 型 
header("Content-Length: 。 227685"): // 文 件 长 度 


header("Accept-Ranges: bytes"); // 接 受 的 范围 单位 
// 缺 省 时 文件 保存 对 话 框 中 的 文件 名 称 
header("Content—Disposition: attachment: filename=$filename"); /实现 下 载 

?> 

(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
< 
mn 401 Unauthorized"); 
header('status: 401 Unauthorized); 
> 

(4) 实现 HTTP 下 载 。 
header("Content-type: application/x-gzip"); 
header("Content-Disposition: attachment filename= 文 件 名 "); 
header("Content-Description: PHP3 Generated Data"); > 
HTTP 标 头 有 很 多 ， 这 里 只 介绍 下 载 的 HTTP 标 头 ， 其 代码 如 下 : 


header('Content-Disposition: attachment; filename="filename"): 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 filename, 即将 filename 蔡 换 为 要 下 载 的 文件 。 


起 味 指 堵 : 请 让 朗 安 | 


力 实例 说 明 


为 了 让 浏览 者 能 够 更 加 细致 地 了 解 所 查询 图 书 的 详细 信息 ， 并 能 够 对 所 选 购 的 图 书 进行 评论 ， 还 需要 通过 
图 书 详细 信息 页 将 图 书信 息 展示 出 来 ， 效 果 如 图 15.30 所 示 。 
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图 15.30 图书 详 细 信息 展示 


图 关键 技术 


图 书 详细 信息 展示 页 中 应 用 的 技术 如 下 : 
(1) 数据 库 的 连接 、 操 作 类 。 
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了 tb_bookinfo.smalltypeid = tb_smalltype.id and tb bookinfo id=" . $bid . "", $connID); // 获 得 图 书信 息 

Ssmarty->assign('bookinfo', $bookinfo); 

代码 说 明 : 

@ 这 里 将 用 户 所 浏览 过 的 图 书 ID 用 字符 “@” 连 接 保存 到 
SESSION 中 。 

@ 函数 array_push0 用 来 将 元 素 添加 到 指定 的 数组 中 。 

(2) 为 了 帮助 读者 选 购 套 系 图 书 ,制订 学 习 流 程 ， 在 制作 明 

日 科技 图 书 网 的 图 书 详细 信息 页 时 ， 增 加 图 书 组 合 购买 功能 ， 其 
效果 如 图 15.31 所 示 。 mkt, 

在 数据 库 中 使 用 tb_book 表 的 bookids 字段 将 组 合 购买 图 书 的 了 
ID 用 字符 “@” 连接 ， 在 bookinfo php 页 面 中 ， 首 先 使 用 函数 se 
explode0 将 组 合 ID 保存 到 数组 中 ， 然 后 使 用 for 循环 语句 遍历 该 数组 ， 根 据 该 数组 元 素 查 询 出 所 有 组 合 图 书信 
息 并 将 图 书信 息 保 存 到 $arrayZhBooks 数组 中 ， 最 后 将 该 数组 传递 给 模板 ， 在 模板 中 通过 section 语句 输出 所 有 
组 合 图 书信 息 ， 其 关键 代码 如 下 : 


SarrayBookids = cxplode( @, $bookinfo[O]['"bookids]); /使 用 字符 “@” 分 隔 组 合 图 书 ID 
SarrayZhBooks = 

S$zhIDs =S$bookinfoolfbid1 . '@’: 

for ($i= 0; $i < count($arrayBookids); $i++) { // 获 得 组 合 ID 图 书信 息 


if (SarayBookids[$i] =") { 
S$tmpBookinfo = $adminDB->executeSQL("select id, bookname, bookimg from tb bookinfo where id=" . $arrayBookids[$i] . "", $connID); 
array push(SarrayZhBooks, StmpBookinfo); 
S$zhIDs .= StmpBookinfool[id] ,@: 
} 
人 SzhIDs): 
Ssmarty->assign('arrayZhBooks', $arrayZhBooks); 
(3) 在 图 书 详细 信息 页 加 入 读者 评论 功能 ， 有 助 于 网 站 经 营 者 分 析 图 书 的 价值 ， 从 而 确定 图 书 在 站 点 中 的 
摆 放 位 置 ， 实 现 评论 功能 的 过 程 如 下 : 
@ 在 图 书 详细 信息 展示 的 模板 页 中 创建 form 表单 ， 将 用 户 评论 提交 到 bookinfo.php 页 面 ， 添 加 到 指定 的 
数据 表 中 。 
@ 在 bookinfo.php 页 面 中 读 取 图 书评 论 信 息 ， 并 且 将 评论 信息 在 模板 页 bookinfo.phtml 中 输出 。 同 时 在 模 
板 页 中 为 图 书评 论 信息 创建 “删除 ” 超 链接 ， 使 评论 的 发 布 者 可 以 删除 自己 的 评论 。 
本 实例 的 完整 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 这 里 不 再 歼 述 。 


国 秘笈 心 法 


心 法 领悟 603: 内 容 简介 和 图 书目 录 之 间 的 切换 。 

在 图 书 详细 信息 展示 的 模板 页 中 ,通过 onmouseover 事件 调用 JavaScript 脚本 中 的 changeTab1() 方 法 实现 在 
内 容 简 介 和 图 书目 录 之 间 的 切换 ， 其 原理 是 通过 onmouseover 事件 调用 JavaScript 脚本 中 的 方法 ， 控 制 <div> 标 
签 样式 的 隐藏 和 展开 。 

应 用 的 过 程 中 ， 唯 一 需要 改动 的 就 是 filename， 即 将 filename 替换 为 要 下 载 的 文件 。 


国 实例 说 明 ， 清 阶 指 证 值 板 亚 县 的 
， 对 于 同一 个 变 县 你， 
在 明日 科技 图 书 网 的 主页 中 有 一 个 新 闻 公 告 展示 模块 ， 用 于 展示 明日 科技 网 站 发 ihe 
布 的 新 闻 公告 信息 ， 其 运行 效果 如 图 15.32 所 示 。 图 15.32 新 闻 公 告 
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在 本 实例 中 ， 运 用 了 两 种 截取 中 文字 符 串 的 方法 。 第 一 种 是 Smarty 模板 中 的 truncate 方法 ， 它 虽然 可 以 对 
中 文字 符 串 进行 截取 ， 但 是 同样 可 能 会 出 现 乱码 的 问题 ;第 二 种 是 自 定义 的 方法 msubstr0， 可 以 防止 截取 中 文 
字符 串 时 出 现 乱 码 ， 在 使 用 时 需要 传递 3 个 参数 ， 指 定 截取 的 字符 串 、 截 取 的 开始 位 置 和 截取 的 长 度 。 


155 站 内 搜索 


搜索 功能 是 一 个 很 重要 且 常 见 的 功能 。 一 个 好 的 搜索 引擎 能 给 用 户 的 使 用 带 来 方便 。 本 节 将 以 明日 科技 图 
书 网 站 中 的 一 般 搜索 和 高 级 搜索 为 例 ， 讲 解 搜索 功能 的 实现 方法 。 


力 实例 说 明 


在 明日 科技 图 书 网 站 的 头 文件 中 ， 设 计 了 一 个 查找 图 书 的 文本 框 ， 其 实现 的 就 是 一 般 搜 索 的 功能 。 在 本 实 
例 中 ， 按 图 书 名称 进 行 搜索 ， 输 入 PHP 关键 字 ， 单 击 “查找 图 书 ” 按 钮 ， 将 输出 如 图 15.33 所 示 的 内 容 。 
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15.33 ”查找 图 书信 息 


力 关键 技术 


在 一 般 搜索 功能 中 ， 关 键 技术 是 应 用 explode() 函 数 对 查询 的 关键 字 进行 拆 分 返回 一 个 数组 。 然 后 通过 for 
循环 语句 读 取 这 个 数组 中 的 元 素 。 最 后 定义 select 查询 中 的 where 子 句 ， 以 数组 中 的 元 素 值 为 like 模糊 查询 的 
条 件 ， 其 关键 代码 如 下 : 


SarrayKeyWord = explode(' ', SkeyWord); // 使 用 空格 对 查询 的 关键 字 进行 拆 分 
Swhere =""; // 定 义 变量 
$j=0: 
for($i=0; $i<count(SarrayKeyWord): $i++){ 1/ 循环 读 取 查询 关键 字数 组 中 的 元 素 
if($arayKeyWord[$i]!="){ // 判 断 数 组 元 素 的 值 是 否 为 空 
if($j>0){ // 如 果 变 量 值 大 于 0 
Swhere .=" or ": // 定 义 where 变量 的 值 


} 
$where .=" tb_bookinfo.bookname like '%".$arrayKeyWord[$i]."%'": ”// 定 义 变量 的 值 ， 即 定义 查询 语句 的 where 子 句 
Sjtt; 
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如 果 参 数 limit 是 负数 ， 则 返回 除 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 


实例 606 高 级 | 


趣味 指数 : 富 食 但 个 


图 实例 说 明 


在 明日 科技 图 书 网 站 的 高 级 搜索 功能 中 ， 可 以 输入 图 书 名 称 关键 字 、 作 者 、 出 版 社 、 类 别 和 出 版 时 间 ， 根 
据 这些 内 容 进 行 综合 查询 ， 高 级 搜索 的 运行 效果 如 图 15.34 所 示 。 
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15.34 ”高 级 搜索 表单 


图 关键 技术 


(1) 应 用 Smarty 模板 中 的 {ldelim} {rdelim} 标 签 在 Smarty 模板 页 中 直接 编辑 JavaScript 脚本 语句 。 
(2) 在 JavaScript 脚本 中 应 用 jQuery 技术 编写 图 书 类 别 展示 的 二 级 联动 菜单 ， 其 关键 代码 如 下 : 


<seript sre=" {util->baseUrl}/js/jqueryjs"></script> <[- 载 入 jQuery 库 -> 
<script language="javascript" > 
S$(document) ready( 
functionO {ldelim} 
S$("#bigtypeid").change(functionO {1delim} 
$.get(" futil->baseUrl}/getstype.php?stid="+$("#bigtypeid").val(), null, fanction(data) {1delim} 
SC"#smalltypeid").emptyO: 
S("#smalltypeid").append(data): 
{rdelim)}): 
{rdelim}); 
{rdelim} 
六 
</script> 
其 中 调用 getstype.php 文件 ， 定 义 图 书 类 别 中 子 类 的 下 拉 列 表 框 值 ，getstype.php 文件 的 代码 如 下 : 
<Iphp 
和 ‘zhine.php'; /包含 配置 文件 
Ssmalltypes = $adminDB->executeSQL("select id, typename from tb_smalltype where bigtypeid=".$_GETT'stid]."", $connID); 
a 


for($i = 0: $i < count($smalltypes); $i++){ // 将 从 数据 库 中 读 取 的 数据 添加 到 下 拉 列 表 的 选项 中 
$data ="<option value—\"".$smalltypes[Si][id"]."\">".iconv('gbk’. ‘utf-8'. $smalltypes[Si][typename'])."</option>"; 


a // 输 出 变量 值 ， 即 输出 下 拉 列 表 框 的 什 
(3) 应 用 Smarty 模板 中 的 html_options 方法 自 定义 函数 设置 日 期 的 下 拉 列 表 框 值 ， 其 部 分 代码 如 下 : 


<select name="fyear"> 
<option value=" selected>- 请 选择 -</option> 
{html options options = $arrayYear} 
</select>&nbsp: 年 
<select name="fmonth"> 
<option value=" selected>- 请 选择 -</option> 
{html_options options = $arrayMonth} 
</select>&nbsp: 月 &nbsp:-&nbsp:-&nbsp: 到 


(4) 定义 高 级 搜索 的 SQL 语句 ， 充 分 发 挥 where 子 句 的 作用 ， 通 过 多 表 查 询 完成 高 级 搜索 的 功能 。 
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(4) 在 search .phtml 模板 页 中 应 用 section 语句 分 页 输出 查询 结果 ， 代 码 请 参考 本 书 光盘 。 


心 法 领悟 606: jQuery 框架 。 

jQuery 由 美国 人 John Resig 创建 ， 至 今 已 吸引 了 来 自 世界 各 地 的 众多 JavaScript 高 手 加 入 其 团队 。jQuery 
是 继 prototype 之 后 又 一 个 优秀 的 JavaScript 框架 ， 其 宗旨 是 WRITE LESS，DO MORE， 即 写 更 少 的 代码 ， 做 更 
多 的 事情 。 它 是 轻 量 级 的 js 库 ( 压 缩 后 只 有 21KB) ， 这 是 其 他 js 库 所 不 及 的 。 它 兼容 CSS3 以 及 各 种 浏览 器 
(IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+ 等 ) 。 

jQuery 是 一 个 快速 的 、 简 洁 的 JavaScript 库 ， 使 用 户 能 更 方便 地 处 理 HTML documents、events、 实 现 动画 
效果 ， 并 且 方 便 地 为 网 站 提供 AJAX 交互 。 

应 用 jQuery 技术 的 前 提 条 件 是 必须 在 项 目 中 载 入 jQuery 库 ， 否 则 无 法 调用 其 中 的 方法 。 


15.6 购 物 车 


购物 车 是 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ”， 为 用 户 在 网 上 购物 提供 了 很 大 的 方便 ， 不 用 担 
心 一 次 购买 多 个 商品 时 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 所 选 商品 放 入 购物 车 中 ， 等 选 购 完成 后 一 起 结算 ， 
购物 车 是 电子 商务 类 网 站 中 一 个 必 不 可 少 的 功能 。 本 节 将 以 明日 网 上 书店 中 的 购物 车 为 模板 ， 详 细 讲 解 购物 车 
的 实现 过 程 。 


En 
用 实例 说 明 


对 于 电子 商务 类 网 站 来 说 ， 安 全 、 稳 定 的 购物 车 模块 是 非常 重要 的 ， 该 模块 直接 关系 到 交易 是 否 能 够 顺利 
进行 。 为 了 提高 代码 的 可 移植 性 ， 在 制作 明日 科技 书店 购物 车 时 ， 将 购物 车 抽象 成 类 ， 封 装 到 library\Cartphp 
文件 中 。 购 物 车 功能 的 运行 效果 如 图 15.35 所 示 。 


痛 购物 济 胃 a 


Ere DB smaah#x 
2 YO mvpas 放 WD et 


国 书 名 千 6 ( 冤 ET 价格 小 寺 【天 ) 六 从 


es 和 
二 疗 两 吕 ; 


“在 大 网 条 时 ,请 下 要 末 用 如 的 =ockie 坟 持 - tT 
“ 购 天 国 书 这 各 中， 于 该 下 要 全 用 浏 和 关 工 具 攻 中 的 “后 朝 ” 定 甸 ， 尽 全 全 用 二 让 太 国内 地 二 的 号 类 失 这 样 可 以 H 目 四 上 委 各 人 让 


15.35 ”购物 车 的 运行 效果 


图 关键 技术 


在 购物 车 类 的 封装 中 ， 应 用 最 多 的 就 是 explode0 函 数 和 implode0 函 数 。 
(1) explode0 函 数 将 字符 串 用 指定 的 子 串 分 隔 ， 并 将 分 隔 结 果 保 存 到 数组 中 。 在 购物 车 类 的 addCart0 方 法 


中 ， 应 用 explode0 函 数 将 ID 串 用 “@ ”分隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 其 关键 代码 如 下 : 
S$armaylds = explode('@'. $this->idStr); /将 王 串 用 “@” 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 


(2) implodeO 函 数 将 指定 数组 中 的 所 有 元 素 使 用 特定 的 字符 进行 连接 形成 新 的 字符 串 ， 其 语法 如 下 : 


(865 
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商品 ID 相同 的 ID 号 ， 则 使 用 函数 unset0 将 数组 元 素 销毁 ， 然 后 再 将 数组 中 所 有 元 素 重新 用 字符 “@ ”连接 成 
商品 ZD 串 ， 这 样 就 可 以 实现 将 指定 的 商品 从 购物 车 中 移 除 的 操作 。 
(5) 使 用 changeNum0 方 法 更 改 购物 车 中 商品 的 数量 ， 其 代码 如 下 : 


function changeNum($goodsId, SgoodsNum){ 
Sarraylds = explode('@', $this->idStr): // 将 商品 人 D 串 用 “@” 分 隔 成 数组 
S$arrayNums = explode('@', $this->numStr); // 将 商品 数量 串 用 “@” 分 隔 成 数组 
for($i= 0; $i < count($arrayIds): $i++){ // 遍 历 商 品 作 串 
if ($arraylds[$i] — $goodsId){ // 如 果 查 找到 要 更 改 的 ID 
SarrayNums[$i] = $goodsNum: /更 改 数量 
1 
} 
Sthis->idStr = implode('@', $arrayIds); /人 重新 合并 成 ZD 串 
S$this->numStr = implode(@' SarrayNums); // 重 新 合并 成 数量 串 


} 

changeNum0 方 法 中 包含 两 个 参数 ， 分 别 为 要 更 改 的 商品 ID 号 和 要 更 改 的 数量 。 在 该 方法 内 部 ， 首 先 使 用 
函数 explode0 将 商品 ID 串 和 商品 数量 串 用 “@” 进 行 分 隔 ， 并 将 分 隔 的 字 串 分 别 保存 到 数组 中 ， 然 后 通过 for 
循环 语句 遍历 商品 ID 数组 ， 在 其 中 查找 要 更 改 数量 的 商品 ID， 查 找到 后 ， 将 新 数量 值 赋 给 数量 串 中 对 应 的 数 
组 元 素 ， 最 后 使 用 函数 implode0 将 商品 ID 数组 和 商品 数量 数组 中 的 所 有 元 素 分 别 重新 用 字符 “@” 进 行 连接 ， 
组 成 新 的 商品 ID 串 和 商品 数量 串 。 

(6) 通过 Cart 类 的 setCartNull0 方 法 ， 清 空 购物 车 中 的 商品 。 实 现 清空 购物 车 中 商品 的 操作 ， 只 需 将 商品 
ID 串 和 商品 数量 串 赋 为 空 值 即 可 ， 其 代码 如 下 : 


fanction setCartNull){ 
Sthis->idStr ="; // 清 空 商品 人 串 
S$this->numStr ="; // 清 空 商品 数量 串 


} 
(7) 通过 购物 车 类 中 的 方法 完成 对 商品 ID 串 和 商品 数量 串 的 操作 后 ， 还 需要 定义 两 个 方法 ， 分 别 用 来 获 


取 商 品 ID 串 和 商品 数量 串 ， 其 代码 如 下 : 
function getIdStrO{ /获得 购物 车 的 商品 ID 串 
return $this->idStr: 


} 
function getNumStrO{ 1/ 获得 购物 车 的 商品 数量 串 
retum $this->numStr; 


} 
以 上 讲解 了 明日 科技 书店 购物 车 功能 的 Cart 类 的 属性 和 主要 方法 ， 其 存储 于 library\Cart.php 文件 中 。 
国 秘笈 心 法 


心 法 领悟 607: 解析 购物 车 类 中 的 商品 ID 串 和 数量 串 。 
购物 车 类 中 的 商品 ID 串 和 商品 数量 串 是 指 用 字符 “@” 连 接 的 多 个 商品 的 ID 号 和 数量 值 ， 其 目的 是 使 用 
一 个 变量 或 者 数据 表 中 的 一 个 字段 存储 多 个 商品 的 ID 或 数量 。 


高 级 | 


实例 608 趣味 指数 : obodolod 


力 实例 说 明 


购物 车 的 主要 功能 是 保留 用 户 选择 的 商品 信息 。 用 户 可 以 在 购物 车 内 设置 选 购 商品 的 数量 、 显 示 选 购 商品 
的 总 金额 ， 还 可 以 进行 清除 选择 的 全 部 商品 信息 、 重 新 选择 商品 信息 等 操作 。 在 实例 607 中 已 经 讲解 了 购物 车 
类 的 实现 过 程 ， 本 实例 将 在 此 基础 上 介绍 购物 车 的 页 面 设计 和 功能 实现 ， 其 中 明日 科技 书店 的 购物 车 运行 效果 
如 图 15.36 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


BD asea se WD spss 
SD musess 所 PE Res 


“在 二 交加 外 时, ea 
“购买 图 书 过 得 中 ， 建 说 不 要 使用 神 | 克扣 工 具 央 中 的 “前 进 ”和 “后 地 ” 扩 镍 ， 尽 重合 用 本 读本 加 内 才 直 的 慰 堪 过 ， 这 样 可 以 防止 本 | 区 关 条 和 
J 民 g 和 于 中卫 名 位 湛江 


图 15.36 明日 科技 书店 购物 车 运行 效果 


图 关键 技术 


购物 车 功能 实现 的 前 提 是 为 每 位 用 户 发 放 一 辆 购物 车 ， 即 为 每 位 用 户 定义 一 个 商品 ID 串 和 商品 数量 串 ， 并 
将 其 保存 在 $_SESSION 全 局 数组 中 。 

所 以 在 购物 车 功能 实现 的 cartphp 文件 中 ， 首 先 要 初始 化 SESSION 变量 ， 判 断 是 否 已 经 设置 了 用 于 保存 商 
品 了 D 串 的 $_ SESSION[sidstr] 数 组 元 素 ， 以 及 保存 商品 数量 串 的 $_ SESSION[mumstr] 数 组 元 素 。 如 果 没有 设 定 ， 
说 明 是 第 一 次 将 商品 添加 到 购物 车 中 ， 则 设置 这 两 个 数组 元 素 的 值 为 空 。 然 后 对 购物 车 类 Cart 进行 实例 化 ， 以 


便 继续 对 购物 车 中 的 商品 进行 增 、 删 、 改 操作 ， 其 关键 代码 如 下 : 
require_once ‘header. php'; // 包 含 网 站 头 文件 以 及 配置 文件 ， 在 配置 文件 中 初始 化 SESSION 变量 
if(! isset($_SESSION['idStr']) | ! isset($_SESSION['numStr])) { 
$_SESSION['idStr] ="; 
$_SESSION['numStr] ="; 
} 
S$cart =new Cart($_SESSION[idstr].$_SESSION[mumstr]); 


这 是 购物 车 功能 实现 的 前 提 条 件 ， 只 有 满足 了 上 述 条 件 ， 才 能 够 继续 执行 购物 车 中 的 增 、 删 、 改 等 功能 。 
图 设计 过 程 

下 面 在 购物 车 类 的 基础 上 讲解 购物 车 各 个 功能 的 实现 过 程 ， 其 操作 在 cart.php 文件 中 进行 

(1) 有 关 购 物 车 的 分 配 已 经 在 关键 技术 中 讲解 ， 这 里 不 再 熬 述 。 

(2) 应 用 购物 车 类 的 addCart0 方 法 将 商品 添加 到 购物 车 ， 其 传递 的 参数 值 分 别 为 购买 商品 的 ID 和 购买 商 
品 的 数量 ,将 商品 成 功 添加 到 购物 车 后 ， 还 需要 使 用 购物 车 类 的 getIdStr0 和 getNumStr0) 方 法 分 页 获取 经 购物 车 


类 处 理 后 的 商品 ID 串 和 商品 数量 串 , 将 获取 结果 分 别 赋 给 $_SESSION 全 局 数组 中 对 应 保存 商品 ID 串 和 商品 数 
量 串 的 数组 元 素 ， 实 现 购物 车 中 商品 刷新 效果 ， 商 品 添加 的 代码 如 下 : 


这 St 一 'add) { // 判 断 操 作 类 型 
S$cart->addCart($_GET[bid] 1); /调用 购物 车 类 的 addCart0 方 法 将 商品 添加 到 购物 车 中 
$_SESSION['idStr] = $cart->getIdStr(); // 获 取 商 品 人 D 串 
$_SESSION['numStr] = $cart->getNumStr(); // 获 取 商 品 数量 串 


} 
(3) 在 实例 607 中 已 经 介绍 过 ， 可 以 将 与 某 本 图 书 相关 的 所 有 图 书 批量 添加 到 购物 车 中 , 其 原理 是 : 首先 ， 
通过 explode0O 函 数 将 保存 组 合 图 书 ID 的 字符 串 用 字符 “@ ”分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 这 样 该 数组 的 
每 个 元 素 为 各 本 组 合 图 书 的 ID 号 。 然 后 ， 通 过 for 循环 遍历 数组 ， 在 遍历 过 程 中 分 别 通过 购物 车 类 的 addCartO) 
方法 将 图 书 添加 到 购物 车 中 ， 其 具体 实现 代码 如 下 : 


这 St 一 'gAdd){ // 判 断 操作 类 型 ， 如 果 为 gAdd 表示 组 合 添加 
S$arrayGIds = explode('@', $, GET[ids]): ID 并 将 结果 保存 到 数组 中 
for($i=0: $i<count($arrayGIds); $i++){ 遍历 数组 

if($arrayGIds[$i]!=" && !in_array($arrayGIds[$i]. explode(@'S ys 
S$cart->addCart(SarrayGIds[$i] .1): 7 分别 将 得 图 书 汪 加 到 购物 车 中 
} 
$_ SESSION[idstr] = $cart->getIdStr(): /重新 为 商品 ID 串 的 SESSION 变量 赋值 
$_SESSION['numStr'] = $cart->getNumStr(): // 重 新 为 商品 数量 串 的 SESSION 变量 赋值 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实例 大 全 (基础 卷 ) 
$_SESSION[toUrl] = 'getbuyuserinfo.html’; 
(8) 在 views 文件 夹 下 新 建 cart.phtml 模板 页 ， 完 成 购物 车 页 面 的 设计 。 
图 秘笈 心 法 


心 法 领悟 608: 判断 指定 的 数据 是 否 为 正 整数 。 

判断 指定 的 数据 是 否 为 正 整数 ， 应 用 到 3 个 函数 : is_numericO、intval0 和 floor()。 

is_numericO) 函 数 检 测 变量 是 否 为 数字 或 者 数字 字符 串 ， 如 果 是 则 返回 TRUE， 和 否则 返回 FALSE。 

intval0 函 数 获取 变量 的 整数 值 。 

floor0 函 数 利用 使 去 法 获取 变量 的 整数 值 。 

在 过 条 件 语句 中 ,判断 is_numeric0 函 数 的 返回 值 是 否 为 TRUE， 判 断 intval0 函 数 的 返回 值 是 否 大 于 0， 判 
断 floor0 函 数 的 返回 值 与 变量 值 是 否 相 等 。 当 满足 is_numericO 函 数 的 返回 值 为 TRUE，intval0 函 数 的 返回 值 大 


于 0， floor0 函 数 的 返回 值 与 变量 值 相 等 时 ， 6 党 盟 变量 是 正 整 数 否则 说 明 不 是 正 整数 ， 其 应 用 方法 如 下 : 
if(! is_numeric(Schangenum) | intval($changenum) <= 0 | floor($changenum) != $changenum) { 
echo 六 拓 天 加 的 如 时 只 对 大 下 业 直 ;</seript>"; 


其 中 变量 Schangenum 为 要 验证 的 变量 。 
15.7 图 书 订 单 处 理 


为 了 方便 用 户 购买 图 书 促进 图 书 销售 ， 在 开发 明日 科技 图 书 网 时 特别 设立 图 书 订单 处 理 模块 ， 通 过 该 模块 
用 户 可 以 方便 地 订购 图 书 并 进行 在 线 支付 。 本 节 将 对 明日 科技 书店 图 书 订单 处 理 模块 进行 讲解 。 


加 we 


力 实例 说 明 

为 了 能 够 将 用 户 所 购买 的 图 书 顺利 邮寄 到 用 户 手中 ， 在 用 户 选择 好 购买 的 图 书后 还 需要 填写 收 货 人 信息 ， 
明日 科技 图 书 网 用 于 填写 收 货 人 信息 的 页 面 如 图 15.37 所 示 ， 在 该 页 面 中 ， 用 户 需 要 填写 个 人 的 真实 联系 信息 、 
收 货 方式 等 内 容 ， 如 果 需 要 发 票 ， 还 需要 填写 发 票 抬头 。 
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图 15.37 填写 收 货 人 信息 的 页 面 
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PHP 开发 实例 大 全 (基础 卷 ) 


Srecpay = 20: 
Ge OU 
Srecpay = 


$_SESSION['recuserinfo']['recpay’] = $recpay: 
echo "<script>window.location href=" . Sutil->baseUrlO . "/deforder html';</script>"; // 重 新 定向 到 deforder.html 页 面 
exit|; 

} 

Ssmarty->display( getbuyuserinfo phtml): 

Tequire_once footerphp': 


图 秘笈 心 法 


心 法 领悟 609: 在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 。 
在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 , 应 用 的 是 Smarty 模板 中 的 $smarty.session 标签 。 首先 在 PHP 
动态 页 中 定义 SESSION 变量 ， 其 格式 如 下 : 


$_SESSION['recuserinfo']['username'] =$ POST[usemame']: 
$_SESSION['recuserinfo']['sex'] =$_POSI[sex]: 

然后 在 Smarty 模板 页 中 ， 通 过 如 下 方法 获取 SESSION 变量 的 值 : 
$smarty.session recuserinfo usemame 

$smarty.session recuserinfo .sex 


目 
赵 味 指数 : 请 良 育 家 


力 实例 说 明 


用 户 填写 完 收 货 人 信息 后 将 进入 订购 信息 确认 页 面 ， 如 图 15.38 所 示 ， 在 该 页 面 中 可 以 查看 并 确认 用 户 所 
订购 图 书 的 名 称 、 单 价 、 总 价格 和 收 货 人 的 信息 。 


便 购物 注 明 和 和 
Waa Ey aaanaaan 


图 书 名 称 空 员 价 《 兄 ; 数量 (本 : 芥 格 十 计 【 兄 ) 


图 15.38 确认 订购 信息 


图 关键 技术 


确认 订购 信息 功能 的 实现 , 首先 应 用 的 是 explode() 函 数 对 商品 ID 串 和 商品 数量 串 中 的 数据 进行 读 取 , 然后 
根据 返回 的 数组 元 素 值 从 数据 库 中 读 取 图 书信 息 ， 完 成 图 书 价格 的 汇总 。 

在 deforder.phtml 模板 页 中 ， 通 过 section 语句 循环 输出 用 户 购买 的 图 书信 息 ， 并 且 通 过 $smarty.session 标签 
输出 收 货 人 的 信息 。 上 述 方法 都 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 不 再 歼 述 。 


图 设计 过 程 
(1) 为 了 使 图 书 订购 流程 的 业务 逻辑 更 加 方便 ， 将 购物 车 和 收 货 人 的 信息 保存 到 SESSION 中 ， 所 以 显示 
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加 载 中 
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PHP 开发 实例 大 全 (基础 卷 ) 
超 链接 ， 将 跳 转 到 如 图 15.39 所 示 的 页 面 ， 输 出 本 次 图 书 订购 的 订单 号 、 支 付 方式 和 需要 支付 的 总 金额 。 


了 消 可 殉 】 [退出 营 孙 ] 


图 15.39 支付 宝 在 线 支 付 
如 果 单 击 图 15.39 中 的 “已 经 确认 订购 信息 按 选择 支付 方式 支付 ” 按钮, 将 跳 转 到 支付 宝 页 面 完 成 支付 操作 。 


图 关键 技术 


使 用 支付 宝 进行 在 线 支付 ， 必 须 先 在 支付 宝 中 注册 一 个 账户 ， 然 后 下 载 
支付 宝 提供 的 接口 文件 ， 实 现 电子 商务 网 站 与 支付 宝 的 交互 。 

在 电子 商务 网 站 中 ,需要 嵌入 支付 宝 提供 的 几 个 文件 , 如 图 15.40 所 示 。 

在 支付 宝 提供 的 接口 文件 中 ， 提 供 了 完整 的 实例 程序 ， 只 要 依照 实例 程 
序 中 的 操作 方法 , 将 电子 商务 网 站 中 指定 的 数据 提交 到 支付 宝 提供 的 数组 参 
数 中， 支付 宝 即 会 通过 自己 定义 的 方法 将 数据 提交 到 指定 的 网 站 中 。 


图 设计 过 程 
(1) 单 击 确认 订购 信息 页 面 中 的 “选择 支付 方式 ”按钮 ， 进 入 如 图 15.41 所 示 的 支付 方式 选择 页 面 。 


slipay_eonfig, 支付 宝 提供 的 文件 


支付 宝 提供 的 文件 
支付 宝 提供 的 文件 
支付 宝 提供 的 文件 
支付 宝 提供 的 文件 


图 15.40 支付 宝 提供 的 文件 


页 两 刚刚 本 


return_url. php- 


和 执 TR9 扩 程 同 共产 吕 


注意， 提供 详 妇 联系 地 址 、 如 如 及 联系 电话 等 信息 


图 15.41 支付 方式 选择 页 面 


新 建 selectpaytype.php 文件 ， 包 含 网 页 的 头 文件 和 尾 文 件 ， 并 指定 模板 页 selectpaytype.phtml; 新 建 
selectpaytype.phtml 模板 页 ， 输 出 各 种 支付 方式 并 且 设 置 进入 指定 支付 方式 的 超 链 接 。 
(2) 单 击 支付 宝 支付 的 “支付 ” 超 链接 ， 将 跳 转 到 确认 支付 方式 页 面 ， 该 页 面 由 defpay.php 和 defpay.phtml 
组 成 。 
在 defpay.php 动态 页 中 , 根据 超 链接 传递 的 参数 值 确定 选择 的 支付 方式 和 类 型 ,并 且 将 存储 在 SESSION 变 
量 中 的 订单 信息 添加 到 数据 表 中 。 同 时 判断 如 果 选 择 的 是 支付 宝 在 线 支付 ($alertType ='2') ， 则 定义 向 支付 宝 
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是 A 9 | - 
RTT iea A 了 aa Mg 下 = 


家 ma 刘 。 


图 15.42 支付 宝 在 线 支 付 图 15.43 工行 在 线 支付 


图 关键 技术 


工行 在 线 支 付 功 能 的 实现 主要 根据 工行 提供 的 在 线 支付 的 接口 ， 将 订单 中 的 数据 以 表单 的 形式 提交 到 工行 
指定 的 网 址 中 。 详 细 的 参数 设置 可 以 参考 工行 提供 的 文档 说 明 书 和 实例 程序 。 

在 实现 与 工行 接口 的 连接 之 前 ， 首 先 要 从 工行 提供 的 说 明 书 中 找到 两 个 文件 ， 开 发 API 接口 LIB\windows\ 
win32\infosecapi.dll (XP 系统 使 用 的 文件 ) 和 开发 API 接口 \ASP\ ICBCEBankUtil.dll， 并 将 其 复制 到 系统 文件 夹 
下 的 Windows\system32 下 ， 在 运行 命令 中 输入 regsvr32 ICBCEBankUtil.dll， 加 载 服 务 。 

通过 PHP 实现 网 站 与 工行 接口 交互 的 方法 如 下 : 

首先 , 通过 com 类 中 的 init0 方 法 对 订单 签名 数据 和 商城 的 公 钥 进 行 加 密 处 理 ， 并 且 将 指定 的 数据 以 表单 的 
形式 提交 到 工行 指定 的 页 面 中 ， 其 关键 代码 如 下 : 


Ssre="ICBC_PERBANK._ B2C1.0.0.0" $infomer["merid"].$infomer["meracct"] Sretumaddress "HS".Sddnumber $amount."0010".$nowtime."0"; 
Scom=new com('ICBCEBANKUTIL.B2CUItil); 
Sre=$com->init("e:\WINDOWS\user.crt","d: \user.crt","d: \user.key","00"): 


SE CS /订单 签名 数据 
Sre=$com->verifySignC(Ssrestrien($sre), Sssre strien(Sssre)); 
Scert=$com->getCert(1); // 商 城 证 书 公 钥 


完成 订单 签名 数据 和 商城 证 书 公 钥 的 加 密 处 理 后 , 将 商户 的 测试 证 书 存储 到 C:\Windows 目录 下 , 设置 商户 
的 私 钥 口令 为 00。 
然后 创建 form 表单 ， 将 指定 的 数据 提交 到 工行 指定 的 网 站 中 。 


图 设计 过 程 
工行 在 线 支付 的 操作 同样 由 defpay.php 和 defpay.phtml 两 个 文件 组 成 。 
(1) 在 defpay.php 动态 页 中 ， 判 断 如 果 选 择 的 是 工行 在 线 支付 ($alertType = '3') ， 则 定义 向 工行 在 线 支 


付 网 站 中 提交 的 数据 ， 并 且 将 数据 赋 给 模板 变量 ， 在 模板 页 中 通过 form 表单 将 数据 提交 到 工行 在 线 支付 的 网 站 
中 。 在 defpay.php 动态 页 中 ， 有 关 工 行 在 线 支 付 的 关键 代码 如 下 : 
<php 


require_once ‘header.php'; 

St=$_GET[Y]; 

让 (St 一 'qyzh) { 
$paytype = "企业 账 户 汇款 ': 
SalertType ="'0'; 

Yelseif ($t = ‘zfb) { 
S$paytype = 支付 宝 在 线 支付 ': 
SalertType ="2'; 

} elseif (St 一 ‘ghzxzf) { 
S$paytype =' 工 行 在 线 支付 
SalertType ="3'; 


} 
/省 略 了 部 分 代码 
if($alertType — 3) { 
Smerlnfo = $adminDB->executeSQL("select merid., meracct from tb_system where mark = 1". $connID): 
Smerid = $merInfo[OlP'merid": 
Smeracct = $merInfo[O]['imeracct ]: 
SmerURL = http://www.mrbooks.cn'; 


876 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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图 15.44 ”后 台 管理 系统 登录 


图 关键 技术 


在 后 台 管 理 系统 登录 功能 实现 过 程 中 ， 应 用 JavaScript 脚本 调用 xym.php 文件 完成 验证 码 的 输出 操作 。 在 
xym.php 文件 中 ， 应 用 文件 系统 函数 库 中 的 函数 将 指定 的 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ， 其 代码 如 下 : 


<?php 

Snum=$_GET[num]; // 获 得 传递 的 数字 
Saddress="img/code/". $num." .gif'; // 获 取 对 应 图 片 地址 
Sfp=fopen($address,"r"); /打开 对 应 的 图 片 

echo fread($fp,filesize($address)); // 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 
felose($fp); /| 关闭 打开 的 图 片 

?> 


有 关 文 件 系统 函数 的 应 用 可 以 参考 本 书 第 4 章 的 内 容 ， 这 里 不 再 熬 述 。 
图 设计 过 程 
明日 科技 图 书 网 后 台 登 录 页 面 的 制作 过 程 主要 包括 登录 表单 的 设计 和 登录 信息 验证 。 


(1) 后 台 用 户 登录 表单 的 UI 是 通过 HTML 语言 的 <input> 标 签 实现 的 , 并 通过 JavaScript 实现 图 片 验证 码 ， 


admin-login.phtml 的 关键 代码 如 下 : 
<form name="form_login" method="post" action=" {util->baseUrl}/admin-login.php" onsubmit="retum chkinputadmin(this)"> 
<div style="width:300px; height:200px; text-align:left"> 
用 户 名 : <input type="text" name="anc" size="22" class="input" /><br /><br /> 
密码 : <input type="password" name="pwd" size="22" class="input" /><br /><br /> 
验证 码 ，<input type="text" name="xym" size="8" class="input" /><input type="hidden" value="" name="xym1"> 
‘<script language="javascript"> 
var numl=Math.round(Math.random()*10000000); 
var num=num]1 .toString().substr(0,4); 
document write("<img name=codeimg4 sre='xym.php?num="+num.substr(0.1)+">"); 
document.write("<img name=codeimgs sre='xym.php?num="+num.substr(1.1)+">"); 
document write("<img name=codeimg6 sre=xym.php?num="+num.substr(2.1)+">"); 
document write("<img name=codeimg7 sre='xym.php?num="+num.substr(3.1)+">"); 
form_login xyml .value=num; 
function code 1(){ldelim} 
var num1=Math.round(Math.random()*10000000); 
var num=numl .toString().substr(0,4); 
document.codeimg4.sre="xym php?num="+num.substr(0,1); 
document.codeimg$.sre="xym. php?num="+nunm.substr(1,1); 
document.codeimg6.sre="xym.php?num="+nunm.substr(2,1); 
document.codeimg7.sre="xym.php?num="+num.substr(3,1); 
form login.xyml .value=num:; 
{rdelim} 
</script> 
<a hre 仁 "javascript:code_10" class="al"> 看 不 清 </a> 
<input type="submit" value=" 登 录 " 广 &nbsp:&nbsp:<input type="reset" valuc=" 重 置 " /> 
</div> 
</form> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<noscript><iframe sre="* html"></iframe></noseript> 
<frameset cols="182. +"> 

<frame sre=" {util->baseUrl}/admin-left php" name="leftwindow"> 
<frame sre=" {util->baseUrl}/admin-main php" name="mainwindow"> 
</frameset><noframes></noframes> 


图 设计 过 程 
后 台 管理 系统 的 主页 主要 由 两 个 文件 组 成 : admin-index.php 和 admin-index.phtml。 
(1) 在 admin-index.php 文件 中 ， 首 先 包 含 系统 的 配置 文件 。 然 后 判断 当前 用 户 是 否 具 有 管理 员 的 权限 ， 


如 果 不 具 备 则 给 出 “禁止 非法 登录 ”的 提示 信息 ， 并 跳 转 到 网 站 的 首页 。 最 后 指定 后 台 管理 系统 主页 的 模板 页 
admin-index.phtml， 其 代码 如 下 : 


require_once ‘zh.inc.php'; 
ifl!lisset($_SESSION['anc']) || $_SESSION['anc] =— "){ 
echo "<script>alert( 禁 止 非法 登录 ! ");window.location href=".$util->baseUrl0."/index.html';</script>"; 
exit(); 
} 
S$smarty->display('admin-index.phtml"); 
(2) 新 建 admin-index.phtml 模板 页 ， 应 用 frame 框架 完成 后 台 管理 系统 主页 的 设计 ， 其 代码 如 下 : 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 明 日 网 上 书店 管理 中 心 </title> 
<link rel="stylesheet" type="text/css" href="css/style.css"> 
</head> 
<noscript><iframe sre="*.html"></iframe></noscript> 
<frameset cols="182, *"> 
<frame src=" {util->baseUrl}/admin-left.php" name="leftwindow"> 
<frame sre=" {util->baseUrl}/admin-main.php" name="mainwindow"> 
</frameset><noframes></noframes> 
(3) 左 侧 导 航 页 面 由 一 个 动态 PHP 文件 admin-left.php 和 一 个 模板 页 admin-left.phtml 组 成 。 在 admin-left. 
php 文件 中 包含 系统 配置 文件 ， 指 定 模 板 页 。 
在 模板 页 admin-left.phtml 中 ， 应 用 jQuery 技术 设计 后 台 管理 系统 的 导航 菜单 ， 通 过 超 链 接 中 的 target 属性 


指定 链接 文件 在 mainwindow 框架 中 输出 ， 其 关键 代码 如 下 : 
<head> 


<title> 明 日 网 上 书店 管理 中 心 - 左 侧 导 航 </title> 

<meta http-equiv="Content-Type" content="text/html; charset="gbk" /> 

<link rel="stylesheet" type="text/css" href=" {util->baseUrl}/css/style.css" /> 
</head> 
<script sre=" {util->baseUrl}/js/jquery.js"></script> 
<script sre=" {util->baseUrl} /js/adminleft.js"></script> 
<div style="width:170px: border:1px solid #FFFFFF"> 

<div id="adminsystembutton" style="width:170px: height:34px; «background-color:#4995A8; cursor:hand: background:url( {util->baseUrl}/img/ 
button xtgl.gif)"> 

</div> 

<div id="adminsystem" style="width:100%px:; height:25px: padding-top:Spx: font-size:13px: background-color:#A3C7D0: line-height:20px; 
display:none"> 

<li style="display:inline; width:100%; text-align:left; padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-default.php" class="al”" 
target="mainwindow"> 系 统 信息 设置 </a></li> 

<li style="display:inline: width:10096: text-align:left; padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-changepwd.php" class="al” 
target="mainwindow"> 更 改 管理 员 密 码 </a></li> 

<li style="display:inline: width:100%: text-align:left: padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-logout.php" class="al" 
target=”parent"> 注 销 退 出 </a></li> 

</div> 
</div> 


(4) 右 侧 页 面 默认 展示 由 admin-main.php 和 admin-main.phtml 文件 组 成 的 内 容 。 在 admin-main.php 文件 
中 ， 首 先 包含 后 台 管 理 系统 的 头 文件 admin-header.php， 然 后 指定 模板 页 admin-main.phtml， 最 后 包含 尾 文件 
admin-footer.php。 在 admin-main.phtml 模板 页 中 ， 输 出 后 台 管 理 系统 的 系统 信息 。 
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心 法 领悟 614: 超 链接 中 target 属性 的 应 用 。 

超 链接 中 target 属性 包含 5 个 属性 值 : _blank 在 新 窗口 中 打开 超 链 接 文件 ，_parent 将 链接 文件 载 入 含有 链 
接 框 架 的 父 框架 或 窗口 中 , 如 果 含 有 该 链接 的 框架 不 是 嵌 套 的 , 则 在 浏览 器 全 屏 窗口 中 载 入 链接 的 文件 , 与 _self 
参数 相同 ，_self 在 同一 框架 或 窗口 中 打开 链接 的 文件 ， 此 参数 为 默认 值 ， 通 常 不 必 指 定 ，_top 在 当前 的 整个 浏 
览 器 窗口 中 打开 链接 的 文件 ， 因 此 会 删除 所 有 框架 ，name 在 指定 的 窗口 或 框架 中 打开 网 页 。 

在 本 实例 的 admin-left.phtml 模板 页 中 ， 通 过 超 链接 的 target 属性 指定 mainwindow 框架 ， 在 该 框架 中 打开 
链接 的 网 页 。 


15.9 系统 管理 


系统 管理 主要 用 于 对 系统 公用 信息 进行 设置 及 对 管理 员 密码 进行 更 改 , 通过 该 模块 可 以 提高 系统 的 可 维护 性 。 


力 实例 说 明 


明日 科技 图 书 网 的 系统 信息 设置 主要 用 于 设置 商城 DD、 企业 账号 、 企 业 版 权 、 联 系 方式 和 程序 文件 的 保存 
路 径 等 信息 ， 系 统 信息 设置 的 页 面 如 图 15.46 所 示 。 
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15.46 系统 信息 设置 页 面 


图 关键 技术 


在 本 实例 中 ， 关 键 之 处 不 在 于 系统 信息 设置 功能 的 实现 方法 ， 更 重要 的 是 它 的 操作 。 在 进行 系统 信息 设置 
时 ， 必 须 设置 最 后 3 项 内 容 ， 它 们 指定 的 是 系统 中 图 片 、 广 告 和 试 读 文 件 的 下 载 地 址 ， 如 果 设 置 的 路 径 不 正确 ， 
那么 这 3 项 内 容 将 不 能 正确 输出 。 

笔者 在 编写 此 实例 时 ， 将 其 路 径 设置 为 http://127.0.0.1/MR/15/005/， 这 是 在 本 地 服务 器 运行 的 路 径 ， 如 果 将 
这 个 程序 上 传 到 互联 网 的 服务 器 中 ， 就 必须 修改 这 个 路 径 ， 否 则 将 找 不 到 指定 的 图 片 和 文件 。 
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图 设计 过 程 


系统 信息 设置 功能 由 admin-default.php 和 admin-default.phtml 两 个 文件 组 成 。 

(1) 在 admin-default.php 文件 中 ， 完 成 数据 库 中 存储 的 系统 信息 的 输出 和 更 新 两 项 操作 。 首 先 包 含 后 台 管 
理 系统 的 头 文件 ， 然 后 判断 form 表单 中 提交 的 merid 值 是 否 为 空 ， 如 果 不 为 室 ， 则 应 用 数据 库 管理 类 的 
executeSQL() 方 法 执行 更 新 语句 ， 更 新 数据 库 中 存储 的 系统 信息 。 最 后 应 用 数据 库 管 理 类 的 executeSQL( 方 法 执 
行 查询 操作 ， 查 询 数据 库 中 存储 的 系统 信息 并 将 其 存储 到 模板 变量 中 ， 其 代码 如 下 : 

<php 


require_once 'admin-header.php'; // 包 含 网 站 头 文件 
if(isset($_POST['merid"]) && $_POST['merid] = ") { // 判 断 表单 提交 的 数据 是 否 为 空 

if (1 $adminDB->executeSQL("update tb system set merid . $ POSTI'merid] . ", meracet=" . $ POST['meracet] . ™, readurl=" , 
$_POST[readurd'] . ", bookimgudi=" . $_POST[bookimgurl] . ", ggur-=" . $_POST[ ggud'] . ", bq=" . $_POST[bq] . ", address=" . 
S POSTTaddress]. "tcl=".$ POSTTtel] . ", ez" . $_POST[ez] . ™, email=" . $_POST[ email] . ", icp=" . $_POST[icp] . ", qq=" . $_POST['aq] . 

™ where mark=1", $connID)) { 
echo "<script>alert(' 系 统 信息 设 置 失败 ! ");</script>"; 
} else{ 
echo "<script>alert( 系 统 信息 设置 成 功 ! ");</script>"; 


} 
Ssystem = $adminDB->exccuteSQL("select id, merid, meracct readurl, bookimgurl, ggurl, bq, address, tcl cz email, icp, qq from tb_system where 
mark=1", $connID); 


Ssmarty->assign('system', $system); // 将 查询 结果 赋 给 模板 变量 
$smarty->display(admin-defaultphtml)); /指定 模板 页 
require_once ‘admin-footer.php'; // 包 含 网 站 尾 文件 


(2) 新 建 admin-default.phtml 模板 页 ， 创 建 form 表单 ， 提 交 需 要 更 新 的 系统 信息 ， 并 且 将 模板 变量 中 传递 
的 系统 信息 作为 表单 元 素 的 默认 值 。 


图 秘 稚 心 ; 
心 法 领悟 615: 通过 JavaScript 脚本 中 的 chkinputsysteminfo0 方 法 验证 表单 元 素 值 。 


在 本 实例 的 admin-default.phtml 模板 页 中 ， 调 用 js/adminfunjs 文件 中 的 chkinputsysteminfo() 方 法 对 系统 信 
息 设置 表单 中 提交 的 数据 进行 验证 。 


力 实例 说 明 


为 了 便于 网 站 管理 者 对 网 站 进行 管理 提高 网 站 的 安全 性 ， 在 系统 管理 模块 增加 管理 员 密 码 修改 功能 ， 
如 图 15.47 所 示 。 


趣味 指数 : 二 从 让 从 | 
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| 下 下 
图 15.47 管理 员 密码 修改 


图 关键 技术 


更 改 管理 员 密码 的 原理 : 用 户 在 上 述 表 单 中 输入 原 密码 和 新 设 定 的 密码 ， 单 击 “ 更 改 ” 按 钮 将 表单 中 的 信 
息 提交 到 admin-changepwd.php 文件 中 对 密码 进行 更 改 , 在 该 文件 中 ,首先 判断 用 户 输入 的 原 密码 是 否 正 确 ， 如 
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果 正 确 则 使 用 数据 库 管理 类 的 executeSQL0O 方 法 执行 update 语句 对 管理 员 密码 进行 更 改 ， 反 之 则 给 出 原 密码 错 
误 的 提示 信息 。 


四 设计 过 程 


后 台 管理 员 密 码 修改 功能 由 admin-changepwd.phtml 和 admin-changepwd.php 两 个 文件 组 成 。 
(1) 新 建 admin-changepwd.phtml 模板 页 ， 创 建 form 表单 ， 将 要 重新 设置 的 密码 提交 到 admin- 
changepwd.php 文件 中 。 
(2) 新 建 admin-changepwd.php 文件 ， 完 成 密码 更 新 操作 。 首 先 ， 验 证 表单 中 提交 的 原始 密码 是 否 正确 ， 
如 果 不 正确 则 给 出 提示 信息 ; 如 果 正 确 ， 执 行 密码 的 更 新 操作 ， 其 代码 如 下 : 


<php 
require_once 'admin-headerphp' // 包 含 网 站 头 文件 
if(isset($_POST['oldpwd']) && $_ POST['oldpwd] !=") { 1/ 判断 用 户 提交 的 原始 密码 是 否 存在 
if(! $adminDB->executeSQL("select id, useme from tb user where usemc=" .$ SESSIONT'anc1." and pwd=" .mds($ POST'oldpwdTD ."", 
S$connID)) { /验证 用 户 提交 的 原始 密码 是 否 正确 


echo "<script>alert( 原 密码 输入 有 误 ! ));</script>"; 
j else{ 

if ($adminDB->executeSQL("update tb_user set pwd=" .mds($_POST[pwdl]) .", truepwd=" .$ POST[pwdl]."where userne=" . 

$_SESSION['anc] . "",$connID)) { /如 果 原 始 密码 正确 ， 则 执行 密码 更 新 操作 
echo "<script>alert(' 密 码 更 改 成 功 ! ):</script>": 
} else{ 
echo "<script>alert(' 密 码 更 改 失败 ! );</script>"; 

} 

， 


} 
$smarty->display(admin-changepwd.phtml); // 指 定 模板 页 


require_once ‘admin-footer. php'; // 包 含 网 站 尾 文件 
图 秘笈 心 ; 


心 法 领悟 616: 通过 chkChangePwd () 方 法 验证 表单 提交 的 信息 。 
在 本 实例 的 admin-changepwd.phtml 模板 页 中 ， 调 用 js/adminfon.js 文件 中 的 chkChangePwd 0 方法 验证 表单 
中 提交 的 新 密码 与 确认 密码 是 否 相 同 ， 并 验证 提交 的 密码 长 度 是 否 大 于 6 个 字 节 。 


15.10 图 书 类 别管 理 


为 了 便于 用 户 选 购 和 查看 图 书信 息 ， 在 明日 科技 图 书 网 的 图 书展 示 模 块 实现 按 图 书 分 类 展示 和 按 出 版 社 分 
类 展示 功能 。 本 节 将 介绍 如 何在 网 站 后 台 对 图 书 类 别 进行 管理 。 


实例 617 ; | 本 和 食 窒 食 个 


看 实例 说 明 

在 明日 科技 图 书 网 中 ， 为 提高 图 书 分 类 层次 ， 在 图 书 分 类 
展示 模块 首先 要 求 用 户 选择 图 书 大 类 ， 然 后 再 选择 图 书 小 类 来 
展示 图 书信 息 列 表 。 图 书 大 类 管理 主要 包括 对 类 别 的 添加 、 修 
改 和 删除 操作 。 图 书 大 类 管理 中 浏览 图 书 大 类 信息 的 页 面 效 果 
如 图 15.48 所 示 。 图 15.48 浏览 图 书 大 类 信息 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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Sbigtypes = $adminDB->executeSQL("select id, typename. addtime from tb_bigtype order by addtime ". SconnID): /循环 读 取 数 据 
S$smarty->assign('bigtypes', $bigtypes): /将 查询 结果 赋 给 模板 变量 
$smarty->display(admin-listbigtype phtmly: /指定 模板 页 

require_once 'admin-footerphp': 


国 秘笈 心 法 


心 法 领悟 617: section 语句 的 应 用 。 
在 输出 图 书 大 类 信息 时 ， 应 用 的 是 Smarty 模板 中 的 section 语句 ， 并 且 调 用 注册 模板 对 象 中 的 unHtml( 方 
法 对 输出 的 数据 进行 格式 化 的 操作 。 


实例 618 


力 实例 说 明 EE a 


ET 


在 图 书 大 类 管理 的 基础 上 为 了 更 加 精确 地 定位 图 书 ， 方 便 读 
者 查找 ， 明 日 科技 图 书 网 的 图 书展 示 模块 又 精确 到 小 类 ， 例 如 ， Var 区 一 
程序 类 图 书 又 精确 到 具体 的 开发 语言 。 在 图 书 小 类 中 添加 小 类 名 一 岂 
称 和 选择 所 属 大 类 的 运行 效果 如 图 15.49 所 示 。 Ea 
关键 技术 图 15.49 图 书 小 类 录入 表单 


在 图 书 小 类 管理 中 ， 应 用 最 多 的 还 是 数据 库 管理 类 中 的 executeSQL() 方 法 ， 由 其 完成 图 书 小 类 数据 的 添加 、 
更 新 、 查 询 和 删除 操作 。 同 时 还 应 用 Smarty 模板 的 html_options 标签 将 所 有 大 类 名 称 在 下 拉 列 表 中 输出 ， 其 代 
码 如 下 : 

<select name="bigtypeid"> 

<option value="">- 请 选择 -</option> 

{html_options options = $arrayBtypeOption} 

</select> 
看 设计 过 程 

(1) 用 户 首先 在 小 类 名 称 文本 框 中 输入 小 类 名 称 ， 然 后 选择 该 小 类 所 属 大 类 ， 单 击 “ 添 加 ”按钮 ， 表 单 内 
容 将 被 提交 到 admin-smalltype.php 文件 中 进行 保存 ，admin-smalltype.php 的 代码 如 下 : 

S$btypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID): /查询 大 类 信息 

for ($i= 0; Si< count($btypes); $i ++) { // 将 大 类 信息 保存 到 数组 中 

S$arrayBtypeOption[$btypes[Sil[id11 = $btypes[S$ill'typename': 

S$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 

证 (isset($_POST[typename']) && $_POST['typename'] (=") { 


if(! $adminDB->executeSQL("select id, typename from tb smalltype where typename=" . trim($ POST'typename"]) . "", $connID)) { 
if(! $adminDB->executeSQL("insert into tb_smalltype(typename. bigtypeid, addtime) values(" . trim($_POST['typename’]) . ", " . 


trim($_POST[bigtypeid]) . "," . date(Y-m-d H:i:s) . ")", $connID)) { /| 执行 添加 操作 
echo "<scriipt>alert( 类 别 添加 失败 ! ”);</seript>"; 
}else{ 


p echo "<script>alert( 类 别 添加 成 功 ! "):</seript>"; 
. 有 "<script>alert(' 该 类 别 已 经 添加 ! ");</script>"; 
} 
上 述 代码 首先 查询 所 有 图 书 大 类 名 称 和 ID 并 保存 到 二 维 数组 中 ， 然 后 通过 Smarty 模板 的 html_options 标 
签 将 所 有 大 类 名 称 在 下 拉 列 表 框 中 输出 ， 然 后 使 用 函数 issetO 判 断 是 否 提交 表单 ， 如 果 是 ， 则 使 用 数据 库 管理 
类 的 executeSQL0O 方 法 保存 小 类 信息 。 


885 


PHP 开发 实例 大 全 (基础 卷 ) 
(2) 在 图 书 小 类 展示 模块 中 ， 主 要 显示 出 图 书 小 类 


的 名 称 、 所 属 大 类 和 小 类 添加 时 间 , 其 运行 效果 如 图 15.50 > Ee 本 | 茹 向 
所 示 。 一 下 5 E23 
单 击 图 书 小 类 信息 列表 页 中 的 编辑 按钮 ,将 出 现 小 类 编 一 ey 
辑 表单 , 用 户 更 改 小 类 信息 并 提交 表单 后 , 表单 内 容 将 被 提 国 4539) 国 汕 小 尖 相 四 列 家 
交 到 admin-listsmalltype.php 文件 中 实现 对 图 书 小 类 信息 的 更 改 ， 其 关键 代码 如 下 : 
S$isShow = 'F'; 
if((isset($_GET[?]) && $_GET[?] = 'edit) || Gisset($_ POST[f]) && $_POST[f] = 'edit)) { 
Sbtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID); ” // 获 得 大 类 信息 
for ($i= 0; $i< count($btypes): $i++) { /将 大 类 信息 保存 到 数组 中 
SarayBtypeOption[Sbtypes[Sil[id]] 一 Sbtgypes[$i][ gpcname]; 
$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 
让 (isset($_POST[f]) && $ POST[?f] = 'edit) { // 进 行 编辑 操作 
if(! enn et ‘update tb_smalltype set typename=" . $_POST['typename'] . ", bigtypeid=" . $_POST['bigtypeid'] . " where 
".$ POST[id] ." 


echo > ;</script>": 
} else{ 
echo "<script>alert( 类 别 更 改 成 功 ! :</script>"; 
} 
} 
if (isset($_GET['id"))) { 
$id=$ GETTid1; 
} else{ 
$id=$ POST[id]; 
SisShow = "T'; 
$smalltype = $adminDB->executeSQL("select id typename, bigtypeid from tb_smalltype where id=" . $id . "", $connID); /查询 小 类 信息 
S$smarty->assign('smalltype’, $smalltype); 


} 

上 述 代码 首先 判断 S_GET[f] 数 组 元 素 是 否 已 经 设置 ， 如 果 是 ， 则 说 明 用 户 单 击 编辑 按钮 ， 这 时 查询 出 所 有 
大 类 名 称 ， 并 使 当前 所 编辑 小 类 的 大 类 名 称 处 于 选中 状态 ， 然 后 判断 是 否 设置 8 POST[f] 数 组 元 素 的 值 ， 如 果 
是 ， 则 说 明 已 经 提交 小 类 信息 更 改 表单 ， 此 时 通过 数据 库 管理 类 的 executeSQL0 方 法 更 改 小 类 信息 。 

(3) 如 果 管 理 员 单 击 小 类 信息 列表 页 中 的 删除 按钮 ， 则 首先 弹出 一 个 提示 框 提 示 用 户 是 否 确认 删除 ， 如 果 


是 ， 则 通过 数据 库 管理 类 的 executeSQL() 方 法 执行 delete 语句 删除 指定 的 小 类 信息 ， 其 代码 如 下 : 
if (isset($_GET[f]) && $_GET[?] = 'del) { 
证 (! $adminDB->executeSQL("delete fiom tb_smalltype where id=" . $_GET[id] . ww, $connID)) { 
ccho "<script>alert( 类 别 删 除 失败 ! <seript>": /执行 删除 
} 
} 


力 秘笈 心 法 


心 法 领悟 618: 应 用 issetO 函 数 判断 指定 的 变量 是 否 存在 。 
issetO 函 数 检查 变量 是 否 被 设置 ， 如 果 设 置 则 返回 TRUE， 和 否则 返回 FALSE。 由 于 这 是 一 个 语言 结构 而 非 函 
数 ， 因 此 它 无 法 被 “变量 函数 ”调用 ， 其 语法 如 下 : 


bool isset (mixed var [, mixed var[ ..]]) 


参数 var 为 被 检查 的 变量 ， 可 以 有 多 个 。 


高 级 | 
实例 619 趣味 指数 : od 
图 实例 说 明 


图 书 不 但 可 以 按 内 容 划 分 ， 还 可 以 按 其 所 属 出 版 社 进行 分 类 ， 这 样 可 以 更 加 方便 地 引导 读者 选 购 自己 信赖 
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的 出 版 社 所 出 版 的 图 书 。 为 使 出 版 社 分 类 更 加 形象 、 易 于 识别 , 在 出 版 社 分 类 中 增加 了 出 版 社 的 Logo 图 片 信息 ， 
浏览 出 版 社 类 别 信息 的 页 面 效果 如 图 15.51 所 示 。 


锥 tn 出 散 社 寺 别 信息 齐 蜗 出 其 社 潜 列 信 息 
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15.51 浏览 出 版 社 类 别 信息 


图 关键 技术 


在 出 版 社 分 类 管理 中 ， 关 键 是 出 版 社 Logo 图 标 上 传 的 实现 方法 ， 其 上 传 应 用 的 是 move_uploaded file0 函 数 。 
(1) 在 执行 上 传 之 前 ， 应 用 is_dir0 函 数 判 断 指定 的 文件 夹 是 否 存在 ， 如 果 不 存 在 则 应 用 mkdir0 函 数 创建 
一 个 新 文件 夹 。 
(2) 应 用 $_FILES[] 全 局 数组 获取 上 传 图 片 的 原始 名 称 。 
(3) 定义 上 传 文件 在 服务 器 文件 夹 下 的 存储 名 称 ， 应 用 date0 函 数 获 取 时 间 戳 ， 应 用 mt_rand0 函 数 定义 随 
机 数 ， 通 过 substr0 函 数 获 取 原 始 文 件 的 后 缀 名 称 ， 从 而 组 成 新 的 文件 名 称 。 
(4) 定义 上 传 文件 在 服务 器 中 的 存储 路 径 。 
(5) 应 用 move_uploaded_file0 函 数 执行 文件 上 传 操作 。 
上 述 函 数 的 详细 讲解 可 以 参考 本 书 第 4 章 的 内 容 ， 这 里 不 再 歼 述 。 


力 设计 过 程 
(1) 网 站 管理 者 在 添加 出 版 社 名 称 并 选择 出 版 社 Logo 图 片 后 ， 单 击 “添加 ”按钮 即 可 将 出 版 社 类 别 信息 
提交 到 admin-pub.php 文件 中 进行 处 理 ， 其 代码 如 下 : 


让 (isset($_POST[pubname]) && $_ POST[pubname] !=") { /如 果 提 交 了 表单 
/判断 该 出 版 社 是 否 已 经 添加 
让 (! $adminDB->executeSQL("select id, pubname from tb_pub where pubname=" .trim($_POST[pubname]) . "",S$connID)) { 
if(isset($_FILES["pubimg"]["name"]) && $_FILES["pubimg"]["name"] (= "") { // 上 传 出 版 社 Logo 


$dir ="./upfiles/bookimg"; 
if(!is dir($diD) { 
mkdir($dir): 


} 
Supfilename = $_FILES["pubimg"]["name"]; 


Sfilename = date("YmdHis") . mt rand(1000. 9999) . substr($upfilename. strpos($upfilename. "."), strlen($upfilename) - 
strpos($upfilename, ".")): 站 是 外 设 社 信 容 演 人 

Saddress = $dir . "/". $filename: 

@move_uploaded_file($_FILES["pubimg"]["tmp_name"], $address): 1/ 执行 上 传 操作 


} else{ 
Sfilename =""; 


证 (! $adminDB->executeSQL("insert into tb pub(pubname. pubimg, addtime) values(™ . trim($ POSTf'pubname"]) . ™, ". $filename . ™, ™ . 
date(Y-m-d H:i's) . ")", $connID)) { /保存 出 版 社 类 别 信息 
echo "<script>alert( 出 版 社 类 别 添加 失败 ! ):</script>"; 
}else{ 
echo "<script>alert(' 出 版 社 类 别 添加 成 功 ! ):</script>"; 
} 
}else{ 
echo "<script>alert( 该 出 版 社 类 别 已 经 添加 ! ):</script>": 
} 
} 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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实例 620 


力 实例 说 明 


明日 科技 图 书 网 的 定位 为 图 书 产品 的 展示 和 和 销售， 所 以 图 书信 息 管理 模块 非常 关键 ， 该 项 目的 图 书信 息 管 
理 模块 主要 包括 对 图 书信 息 的 添加 、 更 改 、 删 除 和 查询 等 操作 。 在 图 书信 息 添加 页 面 中 ， 添 加 的 内 容 包括 图 书 
的 名 称 、 类 别 、 页 数 、 字 数 、 作 者 、ISBN 号 和 价格 等 ， 其 运行 效果 如 图 15.52 所 示 。 
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图 15.52 图 书信 息 添加 


力 关键 技术 


在 图 书信 息 管理 中 ， 非 常 关键 的 一 点 是 明确 数据 表 的 各 个 字段 代表 的 含义 。 在 明日 科技 图 书 网 的 前 台中 ， 
在 对 图 书信 息 进行 分 类 时 ， 依 据 的 就 是 图 书信 息 表 中 某 个 字段 的 值 ， 例如， 判断 图 书 是 否 为 新 书 、 是 否 特价 等 。 
所 以 必须 对 图 书信 息 表 中 各 个 字段 了 如 指 掌 才能 更 好 地 完成 判断 操作 。tb_bookinfo 图 书信 息 表 的 说 明 如 表 15.2 
所 示 。 


表 15.2 tb_bookinfo 图 书信 息 表 


自动 增长 
bookname varchar 大 类 名 称 
smalltypeid datetime 添加 时 间 
oldprice float 书 原价 
newprice float 本 站 价格 
bookimg varchar 图 书 封面 图 片 名 称 
isnew bool 是 否 新 书 
addtime datetime 添加 时 间 
about text 图 书 介绍 
issepprice bool 是 否 特价 图 书 
browsertime 浏览 次 数 
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续 表 
字段 名 称 说 了 明 
ismrbooktj 是 否 *# 科 技 创作 
pubid 出 版 社 
writer 作者 
pubtime 出 版 时 间 
ishave 是 否 有 货 
bookcc 图 书 层次 标识 
Page 图 书页 码 
isbn 图 书 ISBN 号 
zs 图 书 字数 
bc 图 书 版 权 
directory 图 书目 录 
bookids 关联 图 书 ID 所 组 成 的 字符 串 
ishotsell 是 否 热卖 图 书 
isterm 是 否 期 书 


图 设计 过 程 


(1) 管理 员 首先 在 图 15.52 所 示 的 页 面 中 录入 图 书信 息 ， 然 后 单 击 “ 添 加 ”按钮 ， 则 图 书信 息 将 被 提交 到 


admin-book.php 文件 中 并 进行 保存 ， 其 代码 如 下 : 


让 (isset($_ POST[bookname]) && $_POST[bookname] !=" && $_POST['change] — F) { 
if(! $adminDB->executeSQL("select id, bookname from tb_bookinfo where bookname=" . trim($_POST[bookname"]) . "". $connID)) { 
1/ 判断 图 书信 息 是 否 已 经 被 添加 
if (isset($_FILES["bookimg"]["name"]) && $_FILES["bookimg"]["name"] = "") { 
files/bookimg"; 
让 (lis_dir(SdiD){ 
mkdir(Sdin; 
} 
Supfilename =$_FILES["bookimg"]["name"]: 
Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr($upfilename. strpos($upfilename, "."), strlen($upfilename) - 


strpos($upfilename, ". // 设 置 图 书 封面 名 称 
Saddress = $dir . "/". $filename; 
@move_uploaded file($_FILES["bookimg"]["tmp_name"]. $address); /上 传 图 书 封面 
jelse{ 
Sfilename =" 


S$pubtime = $_POST[pyear] . ~ .$_POST[pmonth] . '-00'; 

让 (! $adminDB->executeSQL("insert into tb bookinfo(bookname, smalltypeid, pubid, page, zs, isbn, be, writer, pubtime, oldprice, newprice, 
bookee, boakids bookimg, directory, about, isnew, issepprice, ishotsell, isterm ‘ismrbookt] ishave, addtime, browsertime) value 
trim($_POST[bookname]) . ", "trim($_POSTP'smalltypet i mm .trim(S_ POST[page]) . ", " . trim($_POST['zs"]) . 

". trim($_POST[isbn" time .wm .trim($_ POST[oldprice]) . ™, " 
trim($_POST[newprice Sfilename . ", ". trim($_POS "directory']) . 
trim($_POST['about]) . ™, 3 trim($_POST[ishotsell]) .wm , trim($_POST'isterm']) . 
™,". trim($_POST['ismrbooktj]) . ", " .trim($ POST[ishave]) . ™. " . date('Y-m-d H:i: .0)", SconnID)) { // 保 存 图 书信 息 

echo "<script>alert("| 图 书 添加 失败 1 ;</script>": 
} else{ 
echo "<script>alert( 图 书 添加 成 功 ! ):</script>": 


} 
}else{ 

echo "<script>alert(' 该 图 书 已 经 添加 ! ;</script>"; 
} 


} 
SisEdit = 下: 
让 (isset($_GET[f]) && $_GET[?] — ‘edit ||isset($_POST['change']) && S_ POST[change] 一 T){ 
if(isset($ POST['changeT) &&S POSTI'change|— T) { 
Ee FILES["bookimg"]["name"]) && $_FILES["bookimg"]["name"] (="") { 
="/upfiles/bookimg": 
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(Lis dir(Sdin) { 
mkdir($dir); 


和 
Supfilename = $_FILES["bookimg"]["aame"]: 
Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr($upfilename, strpos($upfilename. "."), strlen($upfilename) - 


addicss = Sai Sl 
; J uploadd filetS FTLES["bookimg"]["tmp name"], Saddress); 
clse 
S$tmpbook = $adminDB->execute SQL("sclect bookimg from tb_bookinfo where id=" . $ POST[id] . "", $connID): 
; S$filename = $tmpbook[O][bookimg']: 
Spubtime =$_POST['pyear] .  . $_POST[pmonth'] . -00'; 
.省略 用 户 设置 提交 内 容 的 代码 ， 请 参见 本 书 光盘 中 源码 
¥f(! SadminDB->exceuteSQL ("update tb_bookinfo set bookname = .trim($_POST[bookname']) . ", smalltypeid=" . 
"pubid=" . trim($_POST['pubid']) . ", page=" . im($_POST['page) . ", 25=" .trim($_POST[zsD) .", isbo=". 
trim($_POSTisbn']) . ", be=" ,trim 人 POST['beD) . ", writer=". trim($_POST[ wwriter)) . ", pubtime=", Spubtime , ", oldprice= 
tin($_POST[oldpriee] . ", newprice=" ,trim($_POST['newprice]) . ", bookee=" . tim(S_POSTIbookec]) . ", bookid ”trim oe 


", bookimg=" . $filename ,ws directory=" . trim($ POSTh directory']) . ", about=" . trim($ POSTTabout]) . ", isnew=" . Sisnew , ", issepprice™ 
Sissepprice . ", ishotsell=" . Sishotsell . ", isterm=". Sisterm . " ,ismrbooktj=". Sismrbooktj . " ,ishave=—". $ishave . " where id=" .$ POST[id] .mw 
SconnID)) { // 更 改 图 书信 息 


echo "<script>alert( 图 书信 息 更 改 失败 ! ');</script>"; 
}else{ 
echo "<script>alert( 图 书信 息 更 改 成 功 ! '):</script>"; 


} 
证 (isset($_ POST[id]){ 
$id=$ POSTTid1; 
j else{ 
$id=$_GET[id]: 
; 
SisEdit = T'; 
Sbook = SadminDB->executeSQL("select id bookname, smalltypeid pubid, Page, zs, isbn, be, writer, pubtime, oldprice, newprice bookee, behits 
bookimg, directory, about, isnew, issepprice. ishotsell, isterm ,ismrbookt] ishave, addtime. browsertime from tb_bookinfo where id=" . $id . " 
$connID): // 查 询 图 书信 息 


$smarty->assign(book', $book); 
ee >assign( pyear, substr($book[O]['pubtime'], 0, 4)): 
Ssmarty->assign('pmonth' substr(Sbook[0][pubtime], 5. 2)); 
在 上 述 代 码 中 ， 定 义 图 书信 息 添加 和 更 新 两 种 操作 。 首 先 判断 5_POST['change'"] 数 组 元 素 的 值 ， 如 果 该 值 为 
F， 则 进行 添加 操作 ， 通 过 数据 库 管理 类 的 executeSQL0 方 法 执行 insert 语句 将 图 书信 息 保存 到 数据 库 中 ， 同 时 
使 用 函数 move_uploaded file0 将 图 书 封面 上 传 到 服务 器 中 ; 如 果 $_POST['change"] 的 值 为 T， 则 执行 图 书信 息 的 
更 改 操作 , 在 更 改 图 书信 息 时 , 首先 判断 是 否 重新 选择 图 书 封面 , 如 果 是 , 则 重新 上 传 图 书 封面 , 然后 执行 update 
语句 对 图 书信 息 进 行 更 新 。 
(2) 图 书信 息 列表 主要 对 图 书 名 称 、 出 版 社 、 作 者 和 价格 等 进行 分 页 显示 ， 其 运行 效果 如 图 15.53 所 示 。 
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图 15.53 图 书信 息 列表 


通过 图 书信 息 列表 页 可 以 实现 对 图 书信 息 的 更 改 和 删除 操作 ， 在 讲解 图 书 添加 操作 中 已 经 介绍 了 图 书信 息 
更 改 的 实现 方法 ， 这 里 不 再 资 述 。 当 单 击 图 书信 息 列表 中 的 删除 按钮 时 ， 首 先 弹出 提示 对 话 框 提示 用 户 是 否 确 


认 删 除 ， 如 果 是 ， 则 通过 如 下 代码 执行 对 图 书信 息 的 删除 操作 : 
让 (isset($_GET[f]) && $_GET[?] —'del) { 
if(! $adminDB->executeSQL("delete from tb_bookinfo where id=" .$_GET[id] .™", $connID)) { 
echo "<script>alert( 图 书信 息 删除 失败 1! ):</script>"; 1/ 执行 删除 操作 
} 
} 
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(3) 与 其 他 管理 模块 相 比 ， 图 书信 息 量 较 大 ， 为 方便 对 图 书信 息 进行 管理 ， 在 图 书信 息 管理 模块 中 增加 了 
图 书信 息 查询 功能 ， 其 运行 效 果 如 图 15.54 所 示 。 


Eee EJ 


查 可 到 阳 图 节 伟 号 
E73 ET 全 ETE ETYYEY] 3 
IT 开 必 各 出 李 过 大 全 人 民 可 ei 所 六 。 | 人 5 天 时 夺 2 沾 卫 各 nm EE 声 二 


图 15.54 图书 信息 查询 
首先 在 文本 框 中 输入 要 查询 的 关键 字 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 这 时 查询 表单 的 关键 字 将 被 提交 到 


admin-searchbook.php 文件 中 ， 在 该 文件 完成 对 图 书信 息 的 查询 操作 ， 并 且 将 查询 结果 赋 给 模板 变量 ， 在 模板 页 
admin-searchbook.phtml 中 输出 查询 结果 ， 其 代码 如 下 : 


SisFind = F'; 
让 (isset($_POST[bookname]) && $ POST[bookname] != "||isset($_GET[bookname]) &&S_GET[bookname]!="){ /判断 是 否 提交 了 表单 
if(isset($_POST['bookname'])) { // 获 取 要 查询 的 图 书 名 称 
$bookname = $_POST['bookname']; 


}else { 
S$bookname = $_GET[bockname]; 
} 
Sbooks = $adminDB->executeSQL("select tb bookinfo id ,tb bookinfo.oldprice, tb bookinfo.newprice, tb bookinfo.bookname, 
tb_bookinfo.writer, tb_pub.pubname from tb_bookinfo, tb_pub where tb_bookinfo.pubid = tb_pub.id and bookname like '%" . $bookname . "%' order 
by tb_bookinfo.addtime desc", $connID): /| 执行 模糊 查询 


} 
上 述 代码 首先 使 用 函数 isset0 判 断 $_POST['bookname'] 数 组 元 素 是 否 已 经 被 设置 ， 如 果 是 ， 则 使 用 数据 库 管 
理 类 的 executeSQL() 方 法 执行 查询 操作 。 


国 秘笈 心 法 
心 法 领悟 620， 通 过 like 关键 字 执行 模糊 查询 ， 查 询 图 书 的 名 称 。 


在 本 实例 的 图 书 查询 中 ， 应 用 like 关键 字 执行 多 表 模 糊 查询 ， 查 询 图 书 的 名 称 ， 并 且 将 查询 结果 返回 到 模 
板 变量 中 。 


力 实例 说 明 


为 了 让 读者 选择 一 本 真正 适合 自己 的 图 书 并 且 吸 引 更 多 
读者 购买 ， 在 制作 明日 科技 图 书 网 时 增加 了 图 书 试 读 模块 ， a 

这 样 读者 在 购买 图 书 前 就 可 以 大 概 了 解 所 购买 图 书 的 内 容 ， | 
非常 人 性 化 。 在 图 书 试 读 信息 添加 页 面 中 包括 图 书 类 别 下 拉 mm 
列表 杠 、 图 书 名 称 选择 下 拉 列表 框 和 试 读 文件 名 称 输入 文本 
框 ， 其 运行 效果 如 图 15.55 所 示 。 图 15.55 添加 图 书 试 读 信息 页 面 


图 关键 技术 


在 添加 图 书 试 读 信息 的 模板 页 admin-read.phtml 中 ,通过 Smarty 模板 中 的 {ldelim} {rdelim} 标 签 直 接 在 模板 
页 中 编写 JavaScript 脚本 ， 应 用 jQuery 技术 实现 下 拉 菜 单 的 三 级 联动 ， 其 关键 代码 如 下 : 


<script sre=" {util->baseUrl}/js/jquery.js"></script> 


第 15 章 ”综合 应 用 


<script language="javascript" > 
S(document) ready( 
fanetion0 {1delim} 
S("#bigtypeid").change(functionO {1delim} 
S$.get("{util->baseUrl} /getstype php?stid="+$("#bigtypeid").val|, null, fanction(data) {1delim} 


S$("#smalltypeid").change(functionO {1delim} 
S$.get(" {util->baseUrl}/getbook.php?bid="+$("#smalltypeid").valO), null, function(data) {ldelim} 
S$("#bookid").emptyO; 
S$("#bookid").append(data); 
{rdelim}); 
{rdelim}); 
a {rdelim} 
</script> 


图 设计 过 程 
(1) 管理 员 在 模板 页 admin-read.phtml 中 输入 图 书 3 试 读 信息 ,将 form 表单 中 的 数据 提交 到 admin-read.php 
文件 中 进行 保存 。form 表单 的 内 容 如 下 : 


<form name="form_read" method="post" action=" {util->baseUrl}/admin-read.php" onsubmit="return chkInputRead(this)"> 
<div style="width:100%; textalign:left padding-top:5px; padding-left:50px"> 类 别 。 &nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp: 
<select id="bigtypeid" name="bigtypeid"> 
<option value=" selected>- 请 选择 -</option> 
{html options options = $arrayBtypeOption} 
</select>&nbsp; 
<select name="smalltypeid" id="smalltypeid"> 
<option value=" selected>- 请 选择 -</option> 
</select> <br /><br /> 
图 书 名 称 : &nbsp;&nbsp; 
<select name="bookid" id="bookid"> 
<option value=" selected>- 请 选择 -</option> 
</select> <br /><br /> 
试 读 文件 名 : <input type="text" name="filename" size="30" class="input"/><br /><br /> 
<input type="submit" value=" 添 加 " />&nbsp:&nbsp:<input type="reset" value=" 重 置 " /> 


</div> 
</form> 
(2) 新 建 admin-read.php 文件 ， 保 存 表 单 中 提交 的 试 读 信息 数据 ， 其 代码 如 下 : 
Sbtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID): // 查 询 图 书 大 类 
for ($i= 0: $i < count($btypes): $i++) { // 将 大 类 保存 到 数组 中 


SarrayBtypeOption[$btypes[Si]["id']] = $btypes[S$i][ typename']; 
S$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 


if(isset($_POST['filename']) && $ POST[ilename] (=") { // 判 断 是 否 提交 了 表单 
if(! $adminDB->executeSQL("select id filename from tb_read where bookinfoid=" .$_ POST[bookid] . ™", $connID)) { 
// 判 断 该 书 的 试 读 信息 是 否 已 经 添加 


证 (! $adminDB->executeSQL("insert into tb read(bookinfoid. filename, addtime) values(" .$ POST'bookid"] .™, " .$ POST['filename'] . 
"date('Y-m-d H:i:s) . ")", $connID)) { 
echo "<scriipt>alert( 试 读 添加 失败 ! ");</seript>"; 
}else{ 
echo "<script>alert( 试 读 添加 成 功 ! );</script>": 


} 
a "<script>alert(' 已 经 为 该 图 书 添加 试 读 ! ):</script>"; 
} 
} 
(3) 试 读 信息 列表 页 主要 以 分 页 的 形式 显示 出 试 读 图 书 的 名 称 、 试 读 文件 名 和 添加 时 间 等 信息 ， 其 运行 效 
果 如 图 15.56 所 示 。 
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共 2 本 要 内 2 示 如 村 第 ! 页 基 革 页 首页 上 一 页 下 一 页 RR 
图 15.56 ”图 书 试 读 信息 列表 


单 击 试 读 信息 列表 的 编辑 按钮 将 出 现 试 读 信息 更 改 表 单 ， 在 该 表单 中 修改 试 读 图 书 的 内 容 ， 将 表单 数据 提 
交 到 admin-listread.php 页 面 中 进行 修改 ， 其 代码 如 下 : 
if (Gisset($_GET[?]) && $ GET[f] 一 edit) || (isset($_POST['?]) && $_POST[f] — 'edit)) { 1/ 判断 是 否 提交 了 表单 
让 (isset($_ POST[f]) && $_ POST[?] — ‘edit) { 

if(! SadminDB->executeSQL("update tb_read set bookinfoid=" . $_POST['bookid] . ". filename=" .$_ POST[filcname] ." where id=" . 

$_POST[id] ."", SconnID)) { 。 /执行 更 改 操作 
echo "<seript>alert( 试 读 更 改 失败 ! <lscripP>": 
else { 
echo "<script>alert(' 试 读 更 改 成 功 ! :</script>"; 
} 


} 

if(isset($_GET[idD) { 
$id=$ GETTid1: 

}else{ 

$id=$_POST[id]; 


SisShow = 'T'; 

Sread = $adminDB->executeSQL("sclect tb_read iid, tb_read filename, tb_bookinfo.bookname, tb_read.addtime from tb_read, tb_bookinfo where 
了 b_read.bookinfoid =tb_bookinfo.id and tb_read.id=". $id . "", SconnID); // 查 询 试 读 信息 

S$smarty->assign('read', Sread); 
} 


单 击 试 读 信息 的 删除 按钮 ， 会 弹出 是 否 确认 删除 的 对 话 框 ， 如 果 选 择 确认 删除 ， 则 执行 如 下 代码 实现 试 读 
信息 的 删除 : 


if(isset($_GET[?]) && $_GET[?] = 'del) { 
if(! $adminDB->executeSQL("delete from tb_read where id=" . $ GET['id'] . "", $connID)) { 
echo "<script>alert(' 试 读 删 除 失败 ! );</script>"; // 执 行 删除 试 读 操作 


} 
图 秘笈 心 法 


心 法 领悟 621: 分 页 功能 的 实现 。 
在 本 实例 中 ， 试 读 信息 的 分 页 输出 应 用 的 是 分 页 类 中 的 pageData0 方 法 ， 将 分 页 查询 结果 赋 给 模板 变量 ， 
在 模板 页 中 创建 分 页 超 链接 ， 完 成 试 读 信息 的 分 页 输出 。 


15.12 用 户 管 理 


用 户 管理 模块 实现 的 功能 包括 对 网 站 注册 用 户 的 管理 和 对 用 户 反馈 信息 的 管理 ， 本 节 将 讲解 这 两 个 功能 的 
实现 过 程 。 


Eeessea 
让 i | dy i 
图 实例 说 明 


在 用 户 信息 管理 模块 中 对 网 站 注册 用 户 进行 分 页 输出 ， 输 出 内 容 包 括 用 户 昵称 、 真 实 姓 名 、 性 别 和 联系 电 
话 等 ， 其 运行 效果 如 图 15.57 所 示 。 
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实例 623 


力 实例 说 明 
用 户 反馈 管理 模块 输出 用 户 对 网 站 本 身 、 网 站 中 的 某 本 图 书 ， 或 者 其 他 方面 的 一 此 建议、 意见 等 ， 其 输出 


效果 如 图 15.58 所 示 。 
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图 15.58 ”浏览 用 户 反馈 信息 


图 关键 技术 


本 实例 实现 的 功能 与 实例 622 是 相同 的 ， 唯 一 的 不 同 之 处 是 本 实例 操作 的 是 tb_feedback 数据 表 ， 而 用 户 信 
息 管理 实例 操作 的 是 tb_user 表 。 
图 设计 过 程 

(1) 浏览 用 户 反 馈 信息 由 admin-listuserfeedback.php 和 admin-listuserfeedback.phtml 两 个 文件 组 成 。 在 


admin-listuserfeedback.php 文件 中 ， 首 先 判断 指定 的 分 页 变量 是 否 存在 ， 然 后 根据 $_GET[] 获 取 的 变量 值 进行 判 
断 ， 执 行 用 户 反馈 信息 的 删除 操作 、 数 据 的 分 页 输出 或 者 查看 指定 用 户 反 馈 的 详细 信息 ， 最 后 指定 模板 页 ， 其 


代码 如 下 : 
<?php 
require_once ‘admin-header.php'; /包含 头 文件 
证 (! ee GET['page']) || $_GET[page] —") { 1/ 判断 分 页 变量 是 否 存在 
Spage = "1'; 
clse{ 
Spage = $_GET[page']: 
if (isset($_GET[?)) && $_GET[?] —'del) { // 判 断 是 否 执行 删除 操作 
if(! $adminDB->executeSQL("delete from tb_feedback where id=" .$_GET[id] . "", $connID)) { 


echo "<script>alert( 用 户 反馈 信息 删除 失败 ! :</script>"; 
} 


} 
$sql ="select id, useme,title addtime from tb_feedback order by addtime desc"; 


Sfeedbacks = $pageDB->pageData($sql, $connID, 20. Spage): /| 执行 分 页 查询 

S$smarty->assign('feedbacks'. $feedbacks): 

SisShow = F'; 

ff(isset($_GET[?]) && $_GET[?] — // 判 断 是 否 执行 详细 信息 查询 操作 

i title, content addtime from tb_feedback where id=" .$_GET[id] . "", $connID): 

SisShow = T'; 
S$smarty->assign('userfeed', $userfeed): // 将 查询 结果 赋 给 模板 变量 

} 

Ssmarty->assign('isShow’, $isShow); 

S$smarty->display('admin-listuserfeedback.phtml): // 指 定 模板 页 

require_once ‘admin-footer.php'; // 包 含 尾 文件 


(2) 新 建 admin-listuserfeedback.phtml 模板 页 。 首 先 通 过 section 语句 循环 输出 用 户 反馈 信息 ， 并 且 创 建 查 
看 指定 用 户 反馈 的 详细 信息 和 删除 指定 用 户 的 超 链 接 。 然 后 定义 分 页 超 链接 ， 完 成 数据 的 分 页 输出 。 最 后 根据 
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续 表 
字段 名 称 说 了 明 
numstr 订购 图 书 数量 组 成 字符 串 
goodsprice 图 书 价格 
yjprice 邮寄 价格 
totalprice 总 价格 
Tectype 收 货 方式 
paytype 支付 方式 
addtime 订购 时 间 
istk 是 否 付 款 
is 也 是 否 发 货 
issh 是 否 收 货 
isqx 是 否 被 用 户 取消 订购 


图 设计 过 程 


用 户 订单 管理 首先 完成 用 户 订单 信息 的 分 页 输出 ， 然 后 执行 订单 支付 状态 的 更 改 、 订 单 信息 的 查看 和 删除 


等 操作 。 


(1) 在 admin-listorder.php 文件 中 ， 首 先 包含 头 文件 ， 根 据 传递 的 查询 字符 串 page 的 值 并 通过 数据 库 分 页 


类 的 pageData0 方 法 实现 订单 信息 的 分 页 输出 。 然 后 通过 数据 库 管 理 类 的 executeSQL( 方 法 ， 执 行 update 语句 
实现 订单 状态 的 更 改 。 最 后 通过 数据 库 管理 类 的 executeSQL( 方 法 执行 select 语句 ， 查 询 指 定 订单 的 详细 信息 ， 
并 且 将 查询 结果 在 模板 页 中 输出 。admin-listorder.php 文件 的 代码 如 下 : 
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<?php 

require_once ‘admin-header.php'; // 包 含 头 文件 

if(! isset($_GET['page']) | $_GET['page] —") { // 判 断 分 页 变量 的 什 
Spage ="1'; 

}else{ 
Spage =$_GET['page']: 


if(isset($_GET[f]) && $_GET[f] = 'del) { // 判 断 是 否 执 行 删除 操作 
证 (! $adminDB->executeSQL("delete from tb_order where id=" .$ GET[id] ."", $connID)) { 
echo "<seript>alert(' 订 单 信息 删除 失败 ! ");</seript>": 
1 


} 
if(isset($_GET[c]) && $_GET['e] =") { // 更 改 订单 状态 
Sc=$_GET[e]: 
if($c=—='isfk) { // 判 断 是 否 已 经 付款 
$adminDB->exeeuteSQL("update tb_order set isfk = !isfk where id=" .$_GET[id] . "", $connID); 
} elseif ($c 一 isfh) { // 判 断 是 否 已 经 发 货 
$adminDB->executeSQL("update tb_order set isth = !isfh where id=" .$_GET[id] . "". $connID); 
} elseif ($c 一 'issh) { // 判 断 是 否 已 经 收 货 


$adminDB->executeSQL("update tb_order set issh = lissh where id=" . $_GET['id] . "", SconnID); 
} 


} 
$sql = "select id orderno, username, tel, goodsprice, yiprice, totalprice. is 全, isfh, issh. isqx from tb order order by addtime desc"; 
// 定 义 SQL 语句 


Sorders = $pageDB->pageData($sql. $connID, 20. Spage): /| 执行 分 页 查询 

S$smarty->assign('orders', $orders): // 将 查询 结果 赋 给 模板 变量 

SisShow = F'; 

让 (isset($_GET[f]) && $_GET[?] —'edit) { // 判 断 是 否 执行 查看 订单 详细 信息 的 操作 


Sorder = $adminDB->executeSQL("select id ordemo. usemame, address, sex. yb, tcL idstr, numstr, rectype, paytype. goodsprice, yjprice, totalprice, 
addtime, isfk. isfh, issh from tb_order where id=" .$_GET[id] ."", $connID); 。 // 执 行 查询 

Sarraylds = explode((@'、 Sorder[O]['idste ]): 

SarrayNums = explode( @". Sorderfo][numstr]): 

SarrayCarlnfos = array(): 

StotalPrice = 0: 

for ($i= 0: $i< count(SarrayIds): $i ++) { 
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Sbookid = $arrayIds[$i]: 
f($bookid =") { 
StmpArray = array(): 
S$bookinfo = $adminDB->executeSQL("select id, bookname ,oldprice, newprice from tb_bookinfo where id=" . $bookid . ™", $connID); 
S$tmpArray[id] = $bookinfo[ol[sd]: 
StmpArray[bookname'] = $bookinfo[O]['bookname']; 
StmpAmayl'oldprice] = Sbookinfo[O][ oldprice ]: 


i Nt 1]; 
StmpArray['smaliTotalPrice'] = Sbookinfo[0][mewprice] * $arrayNums[$i]; 
StotalPrice += $tmpArray['smallTotalPrice: 
array_push($arrayCarInfos, $tmpArray): 
} 
} 


S$smarty->assign('arrayCarlInfos', $arrayCarInfos); /将 生成 的 订单 详细 信息 赋 给 模板 变量 
Ssmarty->assign('‘order.. Sorder): 
SisShow = T': 
} 
S$smarty->assign('isShow', $isShow); // 通 过 该 变量 值 判断 是 否 输出 订单 详细 信息 
Ssmarty->display(admin-listorderphtml): // 指 定 模板 页 
require_once ‘admin-footer.php'; // 包 含 尾 文件 


(2) 在 admin-listorder.phtml 模板 页 中 ， 首 先 通 过 section 语句 循环 输出 订单 信息 ， 创 建 复 选 框 更 改 用 户 订 
单 的 状态 ， 创 建 查 看 订单 详细 信息 和 删除 指定 订单 的 超 链接 。 然 后 创建 数据 分 页 超 链接 ， 完 成 订单 信息 的 分 页 
输出 。 最 后 输出 模板 变量 中 存储 的 指定 订单 的 详细 信息 。 其 关键 代码 如 下 : 

<div style="border-right:1px solid #006D84: {if $orders.data[oID].isqx—1}padding-top:4px{/if}"> 

{下 Sorders.data[oID].isqx 一 1}-- 已 取消 --{else} 付 款 : <input type="checkbox" name="isfk" {if $orders.data[oID]iisftk 一 1}checked{/if} 
onclick="window.location.href="admin-listorder.php?c=isfk&id={$orders.data[oID].id}"™ />&nbsp:&nbsp: 

发 货 ，<input type="checkbox" name="isfh" {if Sorders.data[oID]isth 一 1}checked{/if} 
onclick="window .location href='admin-listorder.php?c=isfh&id= {S$orders.data[oID].id} ">&nbsp;é&nbsp; 

收 货 : <input type="checkbox" name="issh" {if $orders.data[oID].issh 一 1}checked{/if} 
onclick="window location_ href-'admin-listorder php?c=issh&id= {$orders.data[oID].id}"> 

{二 

</div> 

<div style="width:9%; height:20px; float:left; padding-top:2px"> 

<a href=" {util->baseUrl}/admin-listorder.php?{f=edit&id={$orders.data[oID] idj"><img sre=" {util->baseUrl} /img/edit.gif" border="0"/></a>&nbsp; 
<a href="javascript:if(window.confirm(' 确 定 删除 ? ) 一 tmucjfldelim}window location href- futil->bascUrlj/admin-listorderphp?f-del&id= 
{Sorders.data[oID] .id}'; {rdelim} "><img sre=" {util->baseUrl}/img/del.gif" border="0"/></a> 

</div> 
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心 法 领悟 624: 通过 复 选 框 完成 订单 状态 的 更 改 。 

在 admin-listorder.phtml 模板 页 中 创建 复 选 框 ， 通 过 onclick 事件 调用 JavaScript 脚本 ,在 JavaScript 脚本 中 ， 
应 用 window 对 象 的 location 方法 调用 admin-listorder.php 文件 ， 并 传递 两 个 参数 c 和 id， 在 admin-listorder.php 
文件 中 完成 订单 状态 的 更 改 操作 。 


15.14 通用 信息 管理 


在 通用 信息 管理 模块 可 实现 对 新 闻 公 告 、 网 上 畅销 书 讯 和 明日 图 书 排行 管理 ， 本 节 将 讲解 其 功能 的 具体 实 
现 方法 。 


高 级 
趣味 指数 : 位 博 祖 家 | 


实例 625 


力 实例 说 明 
在 新 闻 公告 管理 模块 中 ， 可 实现 新 闻 公 告 的 添加 、 浏 览 、 更 新 和 删除 操作 。 其 中 在 添加 新 闻 公 告 功能 中 ， 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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ifisset($_ POST[id]) && $_POST[id]!="){ 
if(!$adminDB->executeSQL("update tb tcll set title=".$_POST['title].". content=".$_POST['content]." where id=".$_ POST[id]"" 
SconnID){ 
echo "<script>alert( 更 改 失败 ! ");</script>"; 
Jelse { 
echo "<script>alert( 更 改 成 功 ! ");</script>"; 


人 
SisEdit ="T'; 
iflisset($_POST[idD) { // 判 断 提 交 的 ID 值 是 否 为 空 
Sid=$_ POST[id]: 
jelsef 
Sid=$_GET[id]: 


} 
Sinfo = $adminDB->executeSQL("select id, title, content from tb_tell where id=".$id."™", SconnID); // 执 行 查 询 操作 
Ssmarty->assign('info', Sinfo); // 将 查询 结果 赋 给 模板 变量 
} 
S$smarty->assign("isEdit, $isEdit); 
S$smarty->display(‘admin-tell.phtml"): /指定 模板 页 
require_once 'admin-footer php': 
(2) 新 闻 公告 浏览 由 admin-listtelLphp 和 admin-listtell.phtml 两 个 文件 组 成 。 在 admin-listtell.php 文件 中 ， 


首先 定义 删除 指定 新 闻 公 告 的 方法 ， 然 后 执行 新 闻 公告 的 分 页 查询 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 

< 
人 ‘admin-header.php'; // 包 含 头 文件 
ifisset($_GET[f]) && $_GET[?] — "del){ 

if(!$adminDB->executeSQL("delete from tb_tell where id=".$_GET['id]."", $connID)){ 

echo "<script>alert( 公 告 删除 失败 ! ;</script>"; 

} 

} 


$sql = "sclect id, title, addtime from tb_tell order by addtime dese"; // 定 义 分 页 查询 的 SQL 语句 
Stells = $pageDB->pageData($sql, $connID, 20, Spage): // 执 行 分 页 查询 
Ssmarty->assign('tells', $tells); 

S$smarty->display('‘admin-listtell.phtml’): // 指 定 模 板 页 

require_once ‘admin-footer.php'; // 包 含 尾 文件 


在 admin-listtell.phtml 模板 文件 中 ， 通 过 section 语句 循环 输出 新 闻 公 告 信息 ， 并 且 创 建 编辑 和 删除 超 链接 ， 
最 后 编写 分 页 超 链接 ， 其 关键 代码 如 下 : 


<div style="width:10%: height:20px; float:left; padding-top:2px"> 
<a href=" {util->baseUrl} /admin-tell.php?f=edit&id={ S$tells.data[tID].id} "><img sre=" {util->baseUrl} /img/edit. gif" border="0"/></a>&nbsp; 
<a href="javascriptif(window.confirm(" 确 定 删除 ? ")==true) {ldelim}window.location-href="{util->baseUrl}/admin-listtell.php? 人 =del&id= 
{Stells.data[D].id}'; {rdelim} "><img sre=" {util->baseUrl}/img/del.gif' border="0"/></a> 

<ldiv> 
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心 法 领悟 625: 盘点 本 章 实例 。 
本 章 实例 均 提 取 自 明日 科技 网 上 书店 这 个 完整 项 目 ， 其 目的 是 让 读者 了 解 前 面 章节 中 介绍 的 技术 在 实际 项 
目 开发 中 的 应 用 ， 以 此 来 巩固 前 面 所 学 知识 ， 真 正 做 到 理论 与 实践 相 结 合 ， 学 以 致 用 。 
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